数组遍历是编码中很常见的一种需求,我们来扒一拔iOS里面都有什么样的方法来实现,有什么特点。
因为iOS是兼容C语言的,所以C语言里面的最最常见的for循环遍历是没有问题的。
NSArray *numberArray = [[NSArray alloc]initWithObjects:@"1", @"2", @"3", @"4",@"5", nil];
//方法一
//c语言演化过来的
//优点:方便针对下标的处理,就是说如果我要处理i==10的情况是很简便的,另一个是可以比较方便的反向遍历。
//缺点:这个方法最普通,效率也一般
for (int i = 0 ; i < numberArray.count; ++i) {
NSLog(@"C语言 numberArray[%d] = %@", i, numberArray[i]);
}
//方法二
//objective-c 1.0 NSEnumenrator枚举遍历
//优点:对于遍历NSDictionary和NSSet代码也比较类似
//缺点:对于下标的处理会不方便
//反向遍历:另外反向遍历需要用reverseObjectEnumerator方法
NSEnumerator *enumerator = [numberArray objectEnumerator];
//NSEnumerator *enumerator = [numberArray reverseObjectEnumerator];//反向遍历
id object;
while ((object = [enumerator nextObject]) != nil) {
NSLog(@"NSEnumerator枚举 numberArray = %@", object);
}
//方法三
//Objective-C 2.0 快速枚举法
//优点:这里代码简洁清晰,写代码的首选,号称效率也最高
//缺点:如果算法要求知道数组的下标,这个方法就抓瞎了
//反向遍历:另外反向遍历需要用reverseObjectEnumerator方法
//问题,数列逆向排序
for (object in numberArray) {
NSLog(@"快速枚举 numberArray = %@", object);
}
//方法四
//block出来以后iOS里面增加了enumerateObjectsUsingBlock:方法
//优点:参数包括object,下标以及是否停止遍历,应该说,这个能满足基本所有的遍历需求了
//反向遍历:使用这个方法enumerateObjectsWithOptions:usingBlock: 这个方法多传了一个参数,这个参数指定了遍历的顺序。
//比较两个方法:那么这两种方法是一样的么?答案是否定的。在enumerateObjectsWithOptions:usingBlock:方法里面,如果指定了NSEnumerationConcurrent顺序,那么底层通过GCD来处理并发执行事宜,具体实现可能会用到dispatch group。也就是说,这个会用多线程来并发实现,并不保证按照顺序执行,但效率肯定是杠杠的!
[numberArray enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
NSLog(@"block正向遍历 numberArray[%lu] = %@", idx, obj);
}];
[numberArray enumerateObjectsWithOptions:NSEnumerationReverse usingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
NSLog(@"block 反向遍历 numberArray[%lu] = %@", idx, obj);
}];
总结:在iOS中,除数组外,还有NSDictionary和NSSet数据也是称为collection数据的,遍历有类似的地方,不过遍历没有数组那么频繁,方法上是差不多的。