A ------ >遍歷概念
1、集合 ( collection ) OC 中提供的容器 : 數(shù)組,字典齿诞,集合
2、遍歷 :對(duì)集合中元素依次取出的過程叫做遍歷
3骂租、遍歷方式 : 1)for循環(huán)遍歷 ?2)NSEnumerator 遍歷
3)for ... in 遍歷
B ----- > 數(shù)組for遍歷
1掌挚、原理 : 通過for 循環(huán)的循環(huán)變量用作數(shù)組元素下標(biāo)來獲取不同下標(biāo)的元素
2、循環(huán)次數(shù)就是數(shù)組元素的個(gè)數(shù)
for ? ? objectAtIndex : ? NSUInteger ?.count
C ------- > 字典for遍歷
1菩咨、allKeys ---- > for ?keys.count--- > ?objectAtIndex
?---- > objectForKey
C ----- > 集合for遍歷
1吠式、原理 :用集合的 allObjects 屬性先取到集合的所有元素存儲(chǔ)到數(shù)組中, 再通過 for 循環(huán)的循環(huán)變量 用作下標(biāo)來取到每一個(gè)元素
D -------- > NSEnumerator
1抽米、枚舉器 : 遍歷集合中的元素
2特占、依附于集合類,沒有來創(chuàng)建實(shí)例的接口
3云茸、 NSEnumerator 的 nextObject 方法 可以遍歷每個(gè)集合元素是目, 結(jié)束返回 nil , 通過與 while 結(jié)合使用可遍歷集合中所有元素标捺。?
4懊纳、對(duì)可變集合進(jìn)行枚舉操作時(shí), 不能通過添加或刪除對(duì)象這類方式來改變集合容器的元素個(gè)數(shù)
E ----------- >數(shù)組正序枚舉
例子 : NSArray *array = @[ @"element1",@"element2",@"element3",@"element4" ];
NSEnumerator *enumerator = [ array objectEnumerator ]; // 正序枚舉器對(duì)象
id value = nil; ? ?// 存儲(chǔ)數(shù)組中的元素
while ( ( value = [ enumerator nextObject ] ) ) {
? ? NSLog ( @"%@", value );
}
枚舉器的nextObject 方法只能取出一個(gè)對(duì)象亡容, 所以需要 while 循環(huán)結(jié)合把所有元素依次取出
F ------------- > 數(shù)組反向枚舉
NSSArray ? ?- -- > NSEnumerator ( reverseObjectEnumerator ) ---- > while ?nextObject
G ----------- > 字典枚舉遍歷
dictionary ----> enumerator ( objectEnumerator ) --- > nextObject
由于字典中存儲(chǔ)的元素是無序的嗤疯, 因此沒有反向枚舉的概念
H --------------- > for ... int...概述
1、for ?... in... 快速枚舉闺兢, 是在 NSEnumerator的基礎(chǔ)上封裝的更加方便快速的遍歷集合元素的方式
2茂缚、格式 : for ( 集合中對(duì)象的類型 *元素名 in 被遍歷的集合 )
3、對(duì)可變集合進(jìn)行快速枚舉操作時(shí)屋谭, 不能通過添加或者刪除這類方式來改變集合容器的元素個(gè)數(shù)
I ------------- ?> 字典 for ...in... 遍歷
1脚囊、字典快速遍歷, 遍歷到的是字典的 key?
2桐磁、通過key 從字典中獲取相應(yīng)的 value 對(duì)象
J---------- ?> 集合快速遍歷悔耘, 遍歷得到的是集合中的每個(gè)元素
K ---------> ?數(shù)組排序簡(jiǎn)述
1、在程序開發(fā)過程中我擂,有時(shí)我們需要根據(jù)某個(gè)條件對(duì)數(shù)據(jù)進(jìn)行不同的順序展示衬以,此時(shí)就需要對(duì)數(shù)據(jù)進(jìn)行排序
2、數(shù)組是有序容器扶踊,因此集合中只有數(shù)組才能排序
L ?------------- ?> NSSortDescriptor 實(shí)現(xiàn)排序
1泄鹏、該類 能夠方便的實(shí)現(xiàn)對(duì)數(shù)組中的對(duì)象進(jìn)行升序或者降序的排序
2郎任、它可以吧元素的某個(gè)屬性作為 key 進(jìn)行升序或者 降序 的排序秧耗。 每個(gè) NSSortDescriptor 對(duì)象就是一個(gè)排序條件
3、NSSortDescriptor 初始化 方法
- ( instancetype ) initWithKey : ( NSString * ) key
ascending : ( BOOL ) ascending;
1)key : 按照數(shù)組中對(duì)象的那個(gè)屬性進(jìn)行排序舶治, 如果數(shù)組中存放的是能夠直接排序的對(duì)象 ( 比如 : 字符串 )分井,直接用 @self 或者 nil 即可车猬; 如果存放的是自定義的類的對(duì)象, 使用想要排序的屬性名即可 ( 比如: 使用Person 類的 name ?進(jìn)行排序 使用 @name 作為參數(shù) )尺锚。
ascending : 排序的標(biāo)志珠闰, 是升序還是降序 。YES 升序瘫辩, NO - 降序
M -----------> 數(shù)組使用 描述器 排序
數(shù)組根據(jù)排序條件進(jìn)行排序伏嗜, 得到排序好的新的數(shù)組對(duì)象
- ( NSArray *) sortedArrayUsingDescriptors : ( NSArray *) sortDescriptors;
sortDescriptors : 數(shù)組類型的對(duì)象, 數(shù)組中可以存放多個(gè)排序描述對(duì)象 伐厌, 最終實(shí)現(xiàn)能夠按照多個(gè)要求進(jìn)行排序的目的i
N ---------- > 其他不可變數(shù)組排序方法
1承绸、排序結(jié)果生成新數(shù)組, 原數(shù)組無改變
- ( NSArray *) sortedArrayUsingSelector : ( SEL ) comparator;
注 : SEL 類型的參數(shù)是 comparator : 需要傳回一個(gè)比較結(jié)果是 NScomparisonReasult 的方法名
compare: ?字符串的比較方法名 挣轨, 返回值類型正好滿足 SEL 參數(shù)的需要
O---------- ?> 可變數(shù)組排序 ( 直接對(duì)原數(shù)組操作军熏, 無新數(shù)組生成 )
- ( void )sortUsingSelector : ( SEL )comparator;
SEL 類型的參數(shù) comparator ?: ?需要擦混入一個(gè)返回結(jié)果是 NSComparisonResult 的函數(shù)