iOS中遍历数组的方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了iOS中遍历数组的方法相关的知识,希望对你有一定的参考价值。

参考技术A 1.使用普通的for循环

NSArray *ary = @[@"我",@"是",@"张",@"小",@"倍",@"er"];

for (int i = 0; i < ary.count; i ++)

NSLog(@"%@",[ary objectAtIndex:i]);



2.使用for in 进行遍历

NSArray *ary = @[@"我",@"是",@"张",@"小",@"倍",@"er"];

for (NSString *str in ary)

NSLog(@"%@",str);



3.使用do while

NSArray *ary = @[@"我",@"是",@"张",@"小",@"倍",@"er"];

int i = 0;

do

NSLog(@"%@",[ary objectAtIndex:i]);

i ++;

while (i < ary.count);



4.使用while do 

NSArray *ary = @[@"我",@"是",@"张",@"小",@"倍",@"er"];

int i = 0;

while (i < ary.count)

NSLog(@"%@",[ary objectAtIndex:i]);

i ++;



5.使用快速枚举

NSArray *ary = @[@"我",@"是",@"张",@"小",@"倍",@"er"];

[ary enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop)

NSLog(@"%ld,%@,%@",idx ,[ary objectAtIndex:idx],obj);

];

6.

NSArray *ary = @[@"我",@"是",@"张",@"小",@"倍",@"er"];

dispatch_queue_t queue = dispatch_queue_create("queue", DISPATCH_QUEUE_CONCURRENT);

dispatch_apply([ary count],queue, ^(size_t index)

NSLog(@"%ld,%@",index,[ary objectAtIndex:index]);

);

iOS中数组遍历的方法及比較

      数组遍历是编码中非经常见的一种需求。我们来扒一拔iOS里面都有什么样的方法来实现,有什么特点。

      由于iOS是兼容C语言的。所以C语言里面的最最常见的for循环遍历是没有问题的。

      本文中用的数组是获取的系统的语言数组,大约有30多个数据。尽管还不够模拟大批量的数据。但对于方法的验证是没有问题的了。

NSArray *langArray = [[NSUserDefaults standardUserDefaults] arrayForKey:@"AppleLanguages"];
      第一种方法是最最熟悉的C语言演化过来的:

    for (int i = 0; i<langArray.count; i++) {
        NSLog(@"langArray[%d]=%@", i, langArray[i]);
    }
      这种方法最普通,效率也一般,但它也有优点,一是方便针对下标的处理,就是说假设我要处理i==10的情况是非常简便的,还有一个是能够比較方便的反向遍历。


      Objective-C 1.0里面的NSEnumerator也能够进行遍历,代码例如以下:

    NSEnumerator *enumerator = [langArray objectEnumerator];
    id object;
    while ((object = [enumerator nextObject]) != nil) {
         NSLog(@"langArray=%@", object);
    }

      这里我们能够看到没有下标了,通过nextObject的方法来遍历。这种方法的优点是对于遍历NSDictionary和NSSet代码也比較类似,不便的是对于下标的处理会不方便。另外反向遍历须要用reverseObjectEnumerator方法。


      Objective-C发展到2.0时又有了高速遍历功能,代码例如以下:

    for (id object in langArray) {
        NSLog(@"langArray=%@", object);
    }

      这里代码简洁清晰,非常长时间是我写代码的首选。号称效率也最高。只是不便之处相同明显。假设算法要求知道数组的下标,这种方法就抓瞎了。另外,反向须要通过[langArray reverseObjectEnumerator]来实现。


      等到block出来后。iOS里面新添加了enumerateObjectsUsingBlock:的方法,代码例如以下:

    [langArray enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
        NSLog(@"idx=%d, id=%@", idx, obj);
    }];

      这里我们看到block里面的參数包含object。下标以及是否停止遍历。应该说,这个能满足基本全部的遍历需求了,有下标。有执行的对象,还有是否继续遍历的标志。只是反向遍历呢?苹果提供了另外一个方法:

    [langArray enumerateObjectsWithOptions:NSEnumerationReverse usingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
        NSLog(@"idx=%d, id=%@", idx, obj);
    }];

      这个enumerateObjectsWithOptions:usingBlock:方法比enumerateObjectsUsingBlock:方法多传了一个參数,这个參数指定了遍历的顺序。

      讲到这里。假设我们选择正向遍历。那么这两种方法是一样的么?答案也是否定的。在enumerateObjectsWithOptions:usingBlock:方法里面,假设指定了NSEnumerationConcurrent顺序。那么底层通过GCD来处理并发运行事宜,详细实现可能会用到dispatch group。

也就是说,这个会用多线程来并发实现,并不保证依照顺序运行。但效率肯定是杠杠的!

      我们来看一下打印结果:

2014-06-17 15:46:44.413 testStoryboard[2703:3503] idx=32, id=hu
2014-06-17 15:46:44.413 testStoryboard[2703:1303] idx=16, id=ru
2014-06-17 15:46:44.416 testStoryboard[2703:3503] idx=33, id=vi
2014-06-17 15:46:44.412 testStoryboard[2703:60b] idx=0, id=zh-Hant
2014-06-17 15:46:44.417 testStoryboard[2703:1303] idx=17, id=pl
2014-06-17 15:46:44.417 testStoryboard[2703:60b] idx=1, id=zh-Hans
2014-06-17 15:46:44.417 testStoryboard[2703:1303] idx=18, id=tr
2014-06-17 15:46:44.419 testStoryboard[2703:60b] idx=2, id=en
2014-06-17 15:46:44.419 testStoryboard[2703:1303] idx=19, id=uk
2014-06-17 15:46:44.421 testStoryboard[2703:60b] idx=3, id=fr
2014-06-17 15:46:44.421 testStoryboard[2703:1303] idx=20, id=ar
2014-06-17 15:46:44.421 testStoryboard[2703:60b] idx=4, id=de
2014-06-17 15:46:44.422 testStoryboard[2703:60b] idx=5, id=ja
2014-06-17 15:46:44.422 testStoryboard[2703:60b] idx=6, id=nl
2014-06-17 15:46:44.421 testStoryboard[2703:1303] idx=21, id=hr
2014-06-17 15:46:44.423 testStoryboard[2703:60b] idx=7, id=it
2014-06-17 15:46:44.423 testStoryboard[2703:1303] idx=22, id=cs
2014-06-17 15:46:44.423 testStoryboard[2703:60b] idx=8, id=es
2014-06-17 15:46:44.424 testStoryboard[2703:1303] idx=23, id=el
2014-06-17 15:46:44.424 testStoryboard[2703:60b] idx=9, id=ko
2014-06-17 15:46:44.424 testStoryboard[2703:1303] idx=24, id=he
2014-06-17 15:46:44.425 testStoryboard[2703:60b] idx=10, id=pt
2014-06-17 15:46:44.425 testStoryboard[2703:60b] idx=11, id=pt-PT
2014-06-17 15:46:44.425 testStoryboard[2703:1303] idx=25, id=ro
2014-06-17 15:46:44.426 testStoryboard[2703:60b] idx=12, id=da
2014-06-17 15:46:44.426 testStoryboard[2703:1303] idx=26, id=sk
2014-06-17 15:46:44.426 testStoryboard[2703:60b] idx=13, id=fi
2014-06-17 15:46:44.426 testStoryboard[2703:1303] idx=27, id=th
2014-06-17 15:46:44.427 testStoryboard[2703:60b] idx=14, id=nb
2014-06-17 15:46:44.427 testStoryboard[2703:1303] idx=28, id=id
2014-06-17 15:46:44.428 testStoryboard[2703:60b] idx=15, id=sv
2014-06-17 15:46:44.428 testStoryboard[2703:1303] idx=29, id=ms
2014-06-17 15:46:44.429 testStoryboard[2703:1303] idx=30, id=en-GB
2014-06-17 15:46:44.429 testStoryboard[2703:1303] idx=31, id=ca

      从这个结果我们能够看出,确实遍历了整个数组,但并发依照顺序从头到尾——也就是说,用到了dispatch group。这在遍历大数组而有相互独立时对于效率的提高是相当有利的。赞一个!


      在iOS中。除数组外,还有NSDictionary和NSSet数据也是称为collection数据的,遍历有类似的地方,只是遍历没有数组那么频繁。方法上是几乎相同的。      


      






以上是关于iOS中遍历数组的方法的主要内容,如果未能解决你的问题,请参考以下文章

iOS中数组遍历的方法及比較

iOS中数组遍历的方法及比较

iOS中数组遍历的方法及比较

iOS数组遍历删除问题

iOS入门数组遍历

在 iOS 中循环遍历数组