目錄
- 關(guān)于字符串編碼
- NSData
- UIEdgeInsets峡捡、contentInset击碗、contentEdgeInsets
- ios中常用的遍歷運(yùn)算方法
- 排序
1. 關(guān)于字符串編碼
ASCII碼跟Unicode沒(méi)有本質(zhì)的區(qū)別。只不過(guò)Unicode表示范圍比ASCII大们拙。ASCII可以表示127個(gè)英文字母稍途,其中每個(gè)英文字母都有一個(gè)十進(jìn)制編碼,并且通過(guò)這個(gè)十進(jìn)制編碼轉(zhuǎn)化成二進(jìn)制數(shù)(編碼)存入到內(nèi)存當(dāng)中(占1字節(jié))砚婆。 而在Unicode中械拍,英文字母的編碼與其在ASCII中沒(méi)有不同。只是Unicode每個(gè)字符占2個(gè)字節(jié)装盯,于是轉(zhuǎn)化為二進(jìn)制時(shí)就變成‘000000 ASCII’坷虑。
unicode是一個(gè)字符集,utf8是在這個(gè)字符集基礎(chǔ)上的一種具體的編碼方案埂奈。
- 中文解碼
諸如\u82f1\u6587
NSString* strA = [@"%E4%B8%AD%E5%9B%BD" stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
NSString *strB = [@"中國(guó)" stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
- URL編碼:有的時(shí)候會(huì)碰見(jiàn)字符串里有一些特殊字符在轉(zhuǎn)成URL的時(shí)候 會(huì)出現(xiàn)轉(zhuǎn)換不了的情況迄损,這個(gè)時(shí)候需要對(duì)字符串進(jìn)行編碼
首先來(lái)看下什么樣的是URL編碼(字符串中帶有%22 類似這樣的)
NSString *str = @"[http://m.tuniu.com/api/home/data/index/c/%7B%22v%22%3A%227.1.0%22%2C%22ct%22%3A20%2C%22dt%22%3A1%2C%22p%22%3A11210%2C%22cc%22%3A2500%7D/d/%7B%22clientModel%22%3A%22HONOR+H30-L01%22%2C%22width%22%3A720%7D](http://m.tuniu.com/api/home/data/index/c/%7B%22v%22:%227.1.0%22,%22ct%22:20,%22dt%22:1,%22p%22:11210,%22cc%22:2500%7D/d/%7B%22clientModel%22:%22HONOR+H30-L01%22,%22width%22:720%7D%10)"
URL編碼: ios中http請(qǐng)求遇到漢字的時(shí)候,需要轉(zhuǎn)化成UTF-8
//(iOS9.0(包括9.0)以上使用)
NSString *str3 =[str2 stringByAddingPercentEncodingWithAllowedCharacters:[NSCharacterSetURLQueryAllowedCharacterSet]];
//(iOS9.0以下使用)
NSString *str3 =[str2 stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncodind];
URL解碼:請(qǐng)求后,返回的數(shù)據(jù)挥转,如何顯示的是這樣的格式:%3A%2F%2F海蔽,此時(shí)需要我們進(jìn)行UTF-8解碼,用到的方法是
//(iOS9.0(包括9.0)以上使用):
NSString *str2 = [str stringByRemovingPercentEncoding];
//(iOS9.0以下使用)
NSString *str2 =[str stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
- 密碼加密:修改代碼保存密碼不能使用明文绑谣,使用base64進(jìn)行加密党窜。提交數(shù)據(jù)到服務(wù)器不能使用明文,使用base64進(jìn)行加密借宵。
#pragma mark - Base64
編碼:
-(NSString*)base64Encode:(NSString *)string
{
//1.將字符串轉(zhuǎn)換成二進(jìn)制數(shù)據(jù)
NSData *data = [string dataUsingEncoding:NSUTF8StringEncoding];
//2.利用ios7.0的方法幌衣,直接 base64 編碼
return [data base64EncodedStringWithOptions:0];
}
解碼:
- (NSString*)base64Decode:(NSString *)string
{
//1.將base64編碼后的字符串,解碼成二進(jìn)制數(shù)據(jù)
//這里不能使用注釋掉的方法轉(zhuǎn)換成二進(jìn)制,因?yàn)?string 是已經(jīng)編碼過(guò)的字符串
//NSData *data = [string dataUsingEncoding:NSUTF8StringEncoding];
NSData *data = [[NSData alloc]initWithBase64EncodedString:string options:0];
//2.返回解碼的字符串
return [[NSString alloc] initWithData:dataencoding:NSUTF8StringEncoding];
}
2. NSData
NSData介紹
NSData主要是提供一塊原始數(shù)據(jù)的封裝壤玫,用來(lái)包裝數(shù)據(jù)的豁护,NSData存儲(chǔ)的是二進(jìn)制數(shù)據(jù),方便數(shù)據(jù)的封裝與流動(dòng)欲间,屏蔽了數(shù)據(jù)之間的差異楚里,文本、音頻猎贴、圖像等數(shù)據(jù)都可用NSData來(lái)存儲(chǔ)班缎。比較常見(jiàn)的是NSString/NSImage數(shù)據(jù)的封裝與傳遞蝴光。在應(yīng)用中,最常用于訪問(wèn)存儲(chǔ)在文件中达址、網(wǎng)絡(luò)資源中的數(shù)據(jù)以及在多媒體開(kāi)發(fā)時(shí)蔑祟,比較常用,例如拼接音頻沉唠、圖片疆虚。
應(yīng)用場(chǎng)景:
-
存儲(chǔ)本地文本、文件等數(shù)據(jù):
使用archiveRootObject: toFile:
方法可以將一個(gè)對(duì)象直接寫入到一個(gè)文件中满葛,但有時(shí)候可能想將多個(gè)對(duì)象寫入到同一個(gè)文件中径簿,那么就要使用NSData來(lái)進(jìn)行歸檔對(duì)象.NSData可以為一些數(shù)據(jù)提供臨時(shí)存儲(chǔ)空間,以便隨后寫入文件纱扭,或者存放從磁盤讀取的文件內(nèi)容牍帚。
可以使用[NSMutableData data]創(chuàng)建可變數(shù)據(jù)空間儡遮。
NSKeyedArchiver:- 如果對(duì)象是NSString乳蛾、NSDictionary、NSArray鄙币、NSData肃叶、NSNumber 等類型,可以直接用NSKeyedArchiver進(jìn)行歸檔和恢復(fù).
- 但不是所有的對(duì)象都可以直接用這種方法進(jìn)行歸檔十嘿,只有遵守了NSCoding協(xié)議的對(duì)象才可以.
網(wǎng)絡(luò)資源中的數(shù)據(jù):
在進(jìn)行網(wǎng)絡(luò)數(shù)據(jù)通信的時(shí)候因惭,數(shù)據(jù)在網(wǎng)絡(luò)中是二進(jìn)制形式傳輸,加密與解密配套時(shí)可以正確解碼二進(jìn)制流信息绩衷。經(jīng)常會(huì)遇到NSData類型的數(shù)據(jù)蹦魔。在該數(shù)據(jù)是dictionary結(jié)構(gòu)的情況下,可以用NSJSONSerialization
來(lái)解析轉(zhuǎn)換成dictionary咳燕。多媒體開(kāi)發(fā)(音頻勿决、圖片):
通常用于上傳圖片及音頻。
說(shuō)明:NSData根本不管傳遞的內(nèi)容到底是什么招盲,僅僅是傳遞一塊內(nèi)存 —— 僅需內(nèi)存的起始地址和長(zhǎng)度
1. 數(shù)據(jù)相互轉(zhuǎn)換
NSData與字符串的相互轉(zhuǎn)換:
//將字符串轉(zhuǎn)化為NSData
+(NSData *)toNSData:(NSString *)str{
NSError *error = nil;
NSData *aData = [str dataUsingEncoding:NSUTF8StringEncoding];
if (aData.length && error ==nil) {
return aData;
}else{
return nil;
}
}
//將NSData轉(zhuǎn)化為字符串
+(NSString *)transformData:(NSData *)data{
NSError *error = nil;
NSString *string = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
if (string.length && error == nil) {
return string;
}else{
return nil;
}
}
NSData與UIImage的相互轉(zhuǎn)換:
//將NSData轉(zhuǎn)UIImage
UIImage *image = [UIImage imageWithData:data];
//將UIImage轉(zhuǎn)NSData
NSData *data = UIImageJPEGRepresentation(image, 1.0);
NSDictionary -> NSData
// 方法1:NSKeyedArchiver
NSDictionary *dict = @{
@"key1": @"value1",
@"key1": @"value2"
};
NSData *data = [NSKeyedArchiver archivedDataWithRootObject:dict];
// 方法2:NSJSONSerialization
NSError *writeError = nil;
NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dict
options:NSJSONWritingPrettyPrinted
error:&writeError];
if (writeError != nil) {
NSLog(@"Convent to JSON failed: %@", [writeError localizedDescription]);
return;
}
NSData -> NSDictionary
// 方法1:NSKeyedUnarchiver
NSDictionary *myDictionary = (NSDictionary*) [NSKeyedUnarchiver unarchiveObjectWithData:myData];
// 方法2:NSJSONSerialization
NSDictionary *dictFromData = [NSJSONSerialization JSONObjectWithData:dataFromDict
options:NSJSONReadingAllowFragments
NSArray -> NSData
// 方法1:NSKeyedArchiver
NSArray *array = [NSArray arrayWithObjects:@"1",@"2",@"3",nil];
NSData *data = [NSKeyedArchiver archivedDataWithRootObject:arr];
// 方法2:NSJSONSerialization
NSError *writeError = nil;
NSData *jsonData = [NSJSONSerialization dataWithJSONObject:array
options:NSJSONWritingPrettyPrinted
error:&writeError];
if (writeError != nil) {
NSLog(@"Convent to JSON failed: %@", [writeError localizedDescription]);
return;
}
NSData -> NSArray
// 方法1:NSKeyedUnarchiver
NSArray *data2arry = [NSKeyedUnarchiver unarchiveObjectWithData:data];
// 方法2:NSJSONSerialization
NSArray *arrayFromData = [NSJSONSerialization JSONObjectWithData:dataFromArray
options:NSJSONReadingAllowFragments
error:&error];
總結(jié)說(shuō)明:無(wú)論使用NSKeyedUnarchiver還是NSJSONSerialization低缩,其實(shí)它接受的參數(shù)類型都是id,所以我們也可以將繼承自NSObject的自定義類轉(zhuǎn)換為NSData曹货,但該對(duì)象必須遵循NSCoding協(xié)議咆繁,即實(shí)現(xiàn):
- (instancetype)initWithCoder:(NSCoder *)aDecoder;
- (void)encodeWithCoder:(NSCoder *)aCoder;
2. NSData數(shù)據(jù)加密
#import <Foundation/Foundation.h>
@interface NSData (LSCore)
#pragma mark - 加密
// md5
- (NSString*)md5;
// sha
- (NSString *)sha1;
- (NSString *)sha256;
- (NSString *)sha384;
- (NSString *)sha512;
// base64
- (NSString *)base64Encode;
- (NSString *)base64Decode;
// des
- (NSString *)encryptWithKey:(NSString *)key;
- (NSString *)decryptWithKey:(NSString *)key;
// Add libz.dylib to your project.
#pragma mark - gzip
extern NSString* const GzipErrorDomain;
- (NSData*)gzip:(NSError**)error;
@end
3. UIEdgeInsets 、contentInset顶籽、contentEdgeInsets
4. ios中常用的遍歷運(yùn)算方法
想到循環(huán)遍歷數(shù)組玩般、字典這些常見(jiàn)的集合,大家腦子里第一反應(yīng)就是for循環(huán)和快速遍歷礼饱。
ios中常用的遍歷運(yùn)算方法
遍歷的目的是獲取集合中的某個(gè)對(duì)象或執(zhí)行某個(gè)操作坏为,所以能滿足這個(gè)條件的方法都可以作為備選:
- 經(jīng)典for循環(huán)(常用)
- for in (NSFastEnumeration)(常用)
- makeObjectsPerformSelector
- kvc集合運(yùn)算符(效率低)
- enumerateObjectsUsingBlock
- enumerateObjectsWithOptions(NSEnumerationConcurrent)
- dispatch_apply
** 1.第一種方式:經(jīng)典for循環(huán)**
Objective-C是基于C語(yǔ)言的设拟,自然可以使用for循環(huán).
遍歷數(shù)組:
NSArray *iosArray = @[@"L", @"O", @"V", @"E", @"I", @"O", @"S"];
for (int i = 0; i < iosArray.count; i++) {
//處理數(shù)組中數(shù)據(jù)
NSLog(@"%@", iosArray[i]);
}
遍歷數(shù)組很簡(jiǎn)單沒(méi)問(wèn)題,下面遍歷字典.
遍歷字典:
NSDictionary *dict = @{@"1":@"11", @"2":@"22", @"3":@"33"};
NSArray *keysArray = [dict allKeys];
for (int i = 0; i < keysArray.count; i++) {
//根據(jù)鍵值處理字典中的每一項(xiàng)
NSString *key = keysArray[i];
NSString *value = dict[key];
NSLog(@"%@", value);
}
我們知道字典和set是無(wú)序的久脯,所以我們無(wú)法根據(jù)特定的整數(shù)下標(biāo)來(lái)直接訪問(wèn)其中的值纳胧,于是需要先獲取字典中的鍵或者set中的所有對(duì)象,這樣就可以在獲取到的有序數(shù)組上進(jìn)行遍歷了帘撰。然而創(chuàng)建數(shù)組是要額外的開(kāi)銷的跑慕,還會(huì)多創(chuàng)建出一個(gè)數(shù)組對(duì)象,他會(huì)保留collection中的所有對(duì)象摧找,占用了內(nèi)存核行。
總結(jié)優(yōu)缺點(diǎn):
優(yōu)點(diǎn):被廣泛使用,容易接受蹬耘,操作簡(jiǎn)單芝雪;
缺點(diǎn):遍歷字典和set是比較繁瑣,會(huì)占用比較多的系統(tǒng)資源综苔。
** 2.第二種方式:NSEnumerator**
NSEnumerator是一個(gè)抽象基類惩系。其中nextObject是關(guān)鍵方法,它返回枚舉里的下一個(gè)對(duì)象如筛。每次調(diào)用該方法堡牡,其內(nèi)部結(jié)構(gòu)都會(huì)更新,使得下一次調(diào)用方法時(shí)能返回下一個(gè)對(duì)象杨刨。等到枚舉中全部的對(duì)象都已經(jīng)返回之后晤柄,在調(diào)用就會(huì)返回nil,表示達(dá)到了枚舉的末端妖胀。
Foundation框架中的collection都實(shí)現(xiàn)了這種遍歷方式芥颈,例如:
NSArray *array = @[@"L", @"O", @"V", @"E", @"I", @"O", @"S"];
NSEnumerator *enumerator = [array objectEnumerator];//正向遍歷
NSEnumerator *enumerator = [array reverseObjectEnumerator];//反向遍歷
id object;
while ((object = [enumerator nextObject]) != nil) {
//處理枚舉器中的數(shù)據(jù)
NSLog(@"%@", object);
}
字典和set實(shí)現(xiàn)的方式相似,不同的是字典中有key和value赚抡,要根據(jù)具體的key取出value爬坑。同時(shí)提供了正向遍歷和反向遍歷。
總結(jié)優(yōu)缺點(diǎn):
優(yōu)點(diǎn):
代碼更易讀怕品,不需要定義額外的數(shù)組妇垢;
缺點(diǎn):
1、無(wú)法直接獲取遍歷操作的下標(biāo)肉康,需要另外聲明變量記錄闯估;
2、需要自行創(chuàng)建NSEnumerator對(duì)象吼和,稍顯麻煩涨薪。
** 2.第二種方式:快速遍歷**
O快速遍歷與NSEnumerator差不多,然而語(yǔ)法更為簡(jiǎn)潔炫乓,它為for循環(huán)開(kāi)設(shè)了in關(guān)鍵字刚夺,簡(jiǎn)化了遍歷collection所需的語(yǔ)法献丑,例如:
遍歷數(shù)組
NSArray *iosArray = @[@"L", @"O", @"V", @"E", @"I", @"O", @"S"];
for (NSString *obj in iosArray) {
//處理數(shù)組中的數(shù)據(jù)
NSLog(@"%@", obj);
}
遍歷字典也同樣簡(jiǎn)單:
NSDictionary *dict = @{@"1":@"11", @"2":@"22", @"3":@"33"};
for (NSString *key in dict) {
//處理字典的鍵值
NSString *value = dict[key];
NSLog(@"%@", value);
}
反向遍歷可以使用:
for (NSString *obj in [iosArray reverseObjectEnumerator])
總結(jié)優(yōu)缺點(diǎn)
優(yōu)點(diǎn):
語(yǔ)法簡(jiǎn)潔,使用方便侠姑,效率高创橄;
缺點(diǎn):
- 無(wú)法方便獲取當(dāng)前遍歷的下標(biāo);
- 無(wú)法在遍歷過(guò)程中修改被遍歷的collection莽红,否則會(huì)導(dǎo)致崩潰妥畏。
** 4.第四種方式:基于塊的遍歷方式**
遍歷數(shù)組
NSArray *iosArray = @[@"L", @"O", @"V", @"E", @"I", @"O", @"S"];
[iosArray enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
NSLog(@"%@", obj);
if ([obj isEqualToString:@"E"]) {
*stop = YES;
}
}];
參數(shù)說(shuō)明:
obj表示數(shù)組中的元素;
idx表示元素的下標(biāo);
stop可以控制遍歷何時(shí)停止,在需要停止時(shí)令stop = YES即可(不要忘記前面的)安吁。
這種方法清晰明了醉蚁,數(shù)組元素,下標(biāo)都可直接獲取鬼店,就連何時(shí)停止都很容易實(shí)現(xiàn)网棍,break都可以退休了,遍歷字典也同樣簡(jiǎn)單妇智。
遍歷字典
NSDictionary *dict = @{@"1":@"11", @"2":@"22", @"3":@"33"};
[dict enumerateKeysAndObjectsUsingBlock:^(id _Nonnull key, id _Nonnull obj, BOOL * _Nonnull stop) {
NSLog(@"%@", obj);
if ([obj isEqualToString:@"22"]) {
*stop = YES;
}
}];
你沒(méi)有看錯(cuò)滥玷,就是這么簡(jiǎn)單,block直接把字典的key和value都給我們了俘陷,再也不用書寫直白而繁瑣的代碼了罗捎。
注意:
若已知collection里對(duì)象的數(shù)據(jù)類型,可以修改塊簽名拉盾,知道對(duì)象的精確類型后,編譯器就可以檢測(cè)開(kāi)發(fā)者是否調(diào)用了該對(duì)象所不具有的方法豁状,并在發(fā)現(xiàn)問(wèn)題時(shí)報(bào)錯(cuò)捉偏。
NSDictionary *dict = @{@"1":@"11", @"2":@"22", @"3":@"33"};
[dict enumerateKeysAndObjectsUsingBlock:^(NSString *key, NSString *obj, BOOL * _Nonnull stop) {
NSLog(@"%@", obj);
if ([obj isEqualToString:@"22"]) {
*stop = YES;
}
}];
如代碼,直接把key和value的類型修改成NSString類型泻红。
反向遍歷
反向遍歷也同樣方便夭禽,調(diào)用另外一個(gè)方法即可:
NSArray *iosArray = @[@"L", @"O", @"V", @"E", @"I", @"O", @"S"];
[iosArray enumerateObjectsWithOptions:NSEnumerationReverse usingBlock:^(NSString *obj, NSUInteger idx, BOOL * _Nonnull stop) {
NSLog(@"%@", obj);
if ([obj isEqualToString:@"E"]) {
*stop = YES;
}
}];
這個(gè)方法相對(duì)于正向遍歷多了一個(gè)枚舉類型的參數(shù)NSEnumerationReverse,打開(kāi)這個(gè)選項(xiàng)就可以反向遍歷了谊路。
并發(fā)遍歷
順著這個(gè)枚舉類型的參數(shù)讹躯,就會(huì)引出塊枚舉的另一大優(yōu)勢(shì):并發(fā)遍歷,參數(shù)是:NSEnumerationConcurrent缠劝,也就是可以同時(shí)遍歷collection中的幾個(gè)元素潮梯,具體數(shù)量根據(jù)系統(tǒng)資源而定。這樣會(huì)充分利用系統(tǒng)資源惨恭,高效快捷的完成collection的遍歷秉馏,系統(tǒng)底層會(huì)通過(guò)GCD來(lái)處理并發(fā)事宜,開(kāi)發(fā)者不需要擔(dān)心內(nèi)存和線程脱羡,其他方式若要實(shí)現(xiàn)高效的并發(fā)遍歷十分有難度萝究。通過(guò)塊枚舉遍歷免都,改變collection并不會(huì)引起崩潰,代碼如下:
NSArray *iosArray = @[@"L", @"O", @"V", @"E", @"I", @"O", @"S"];
NSMutableArray *iosMutableArray = [NSMutableArray arrayWithArray:iosArray];
[iosMutableArray enumerateObjectsWithOptions:NSEnumerationConcurrent usingBlock:^(NSString *obj, NSUInteger idx, BOOL * _Nonnull stop) {
obj = [NSString stringWithFormat:@"_%@", obj];
[iosMutableArray replaceObjectAtIndex:idx withObject:obj];
NSLog(@"%@", obj);
if ([obj isEqualToString:@"_I"]) {
*stop = YES;
}
}];
優(yōu)缺點(diǎn)總結(jié)
優(yōu)點(diǎn):
- 可以完美實(shí)現(xiàn)for循環(huán)的所有功能帆竹;
- 可以方便獲取集合中的每一項(xiàng)元素绕娘;
- 提供了循環(huán)遍歷的參數(shù),NSEnumerationReverse用來(lái)實(shí)現(xiàn)倒序循環(huán)栽连。NSEnumerationConcurrent用來(lái)實(shí)現(xiàn)并發(fā)遍歷业舍,兩個(gè)參數(shù)可以同時(shí)使用;
- 這種循環(huán)方式效率高升酣,能夠提升程序性能舷暮,開(kāi)發(fā)者可以專注于業(yè)務(wù)邏輯,而不必?fù)?dān)心內(nèi)存和線程的問(wèn)題噩茄;
- 當(dāng)開(kāi)啟NSEnumerationConcurrent選項(xiàng)時(shí)下面,可以實(shí)現(xiàn)for循環(huán)和快速遍歷無(wú)法輕易實(shí)現(xiàn)的并發(fā)循環(huán)功能,系統(tǒng)底層會(huì)通過(guò)GCD處理并發(fā)事宜,這樣可以充分利用系統(tǒng)和硬件資源唉地,達(dá)到最優(yōu)的遍歷效果戒劫;
- 可以修改塊簽名,當(dāng)我們已經(jīng)明確集合中的元素類型時(shí)机杜,可以把默認(rèn)的簽名id類型修改成已知類型,比如常見(jiàn)的NSString衅谷,這樣既可以節(jié)省系統(tǒng)資源開(kāi)銷椒拗,也可以防止誤向?qū)ο蟀l(fā)送不存在的方法是引起的崩潰。
缺點(diǎn):
- 很多開(kāi)發(fā)者不知道這種遍歷方式获黔;
- 這里使用了block蚀苛,需要注意在block里容易引起的保留環(huán)問(wèn)題,比如使用self調(diào)用方法時(shí)玷氏,把self轉(zhuǎn)化成若引用即可打破保留環(huán)堵未。如:
weak `typeof(self)weakSelf = self
或者
__weak MyController *weakSelf = self;
在block里使用weakSelf即可。
注意
使用基于塊的遍歷時(shí)是可以修改遍歷的元素的盏触,不會(huì)導(dǎo)致崩潰渗蟹,但是如果要?jiǎng)h除遍歷的元素會(huì)導(dǎo)致后面的元素?zé)o法遍歷而崩潰,解決辦法有2種:
一種是復(fù)制一份原集合的副本赞辩,對(duì)副本進(jìn)行操作雌芽,找出所要操作的元素后再處理原集合;
使用反向遍歷诗宣,反向遍歷刪除元素后不會(huì)導(dǎo)致崩潰膘怕。
5. 排序
數(shù)組是有序容器,因此集合中只有數(shù)組才能排序。
不可變數(shù)組排序
方法1
NSArray *arr = @[@"aa",@"rr",@"pp",@"hh",@"xx",@"vv"];
//用系統(tǒng)的方法進(jìn)行排序,系統(tǒng)缺少兩個(gè)元素比較的方法.
//selector方法選擇器.
NSArray *sortArr = [arr sortedArrayUsingSelector:@selector(compare:)];
NSLog(@"%@",sortArr);
方法2:block塊語(yǔ)法
[arr sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {
return [(NSString *)obj1 compare:(NSString *)obj2];
}];
NSLog(@"%@",arr);
}
可變數(shù)組排序
方法1
NSMutableArray *arr = [@[@54 ,@33,@12,@23,@65] mutableCopy];
[arr sortUsingSelector:@selector(compare:)];//compare數(shù)組中兩個(gè)元素比較的方法
NSLog(@"%@",arr);
方法2
[arr sortUsingComparator:^NSComparisonResult(id obj1, id obj2) {
return [(NSNumber *)obj1 compare:(NSNumber *)obj2];
}];
NSLog(@"%@",arr);
}