OC遍历(官方推荐)

NSArray*iosArray =@[@"L",@"O",@"V",@"E",@"I",@"O",@"S"];

```

```

[iosArrayenumerateObjectsUsingBlock:^(id_Nonnullobj,NSUIntegeridx,BOOL*_Nonnullstop) {

NSLog(@"%@", obj);

if([objisEqualToString:@"E"]) {

*stop =YES;

}

}];

```

参数说明:obj表示数组中的元素,idx表示元素的下标,*stop可以控制遍历何时停止,在需要停止时令*stop = YES即可(不要忘记前面的*)。

这种方法清晰明了,数组元素,下标都可直接获取,就连何时停止都很容易实现,break都可以退休了,遍历字典也同样简单。

NSDictionary*dict =@{@"ios":@"11",@"jave":@"22",@"oc":@"33"};

[dictenumerateKeysAndObjectsUsingBlock:^(id_Nonnullkey,id_Nonnullobj,BOOL*_Nonnullstop) {

NSLog(@"key = %@", key);

NSLog(@"obj = %@", obj);

if([objisEqualToString:@"22"]) {

*stop =YES;

}

}];

若已知collection里对象的数据类型,可以修改块签名,知道对象的精确类型后,编译器就可以检测开发者是否调用了该对象所不具有的方法,并在发现问题时报错。


NSDictionary*dict =@{@"ios":@"11",@"jave":@"22",@"oc":@"33"};

[dictenumerateKeysAndObjectsUsingBlock:^(NSString*key,NSString*obj,BOOL*_Nonnullstop) {

NSLog(@"key = %@", key);

NSLog(@"%@", obj);

if([objisEqualToString:@"22"]) {

*stop =YES;

}

}];


如代码,直接把key和value的类型修改成NSString类型。

反向遍历:

反向遍历也同样方便,调用另外一个方法即可:


NSArray*iosArray =@[@"L",@"O",@"V",@"E",@"I",@"O",@"S"];

[iosArrayenumerateObjectsWithOptions:NSEnumerationReverseusingBlock:^(NSString*obj,NSUIntegeridx,BOOL*_Nonnullstop) {

NSLog(@"%@", obj);

if([objisEqualToString:@"E"]) {

*stop =YES;

}

}];


这个方法相对于正向遍历多了一个枚举类型的参数NSEnumerationReverse,打开这个选项就可以反向遍历了。

并发遍历:

顺着这个枚举类型的参数,就会引出块枚举的另一大优势:并发遍历,参数是:NSEnumerationConcurrent,也就是可以同时遍历collection中的几个元素,具体数量根据系统资源而定。这样会充分利用系统资源,高效快捷的完成collection的遍历,系统底层会通过GCD来处理并发事宜,开发者不需要担心内存和线程,其他方式若要实现高效的并发遍历十分有难度。通过块枚举遍历,改变collection并不会引起崩溃,代码如下:

NSArray*iosArray =@[@"L",@"O",@"V",@"E",@"I",@"O",@"S"];

NSMutableArray*iosMutableArray = [NSMutableArrayarrayWithArray:iosArray];

[iosMutableArrayenumerateObjectsWithOptions:NSEnumerationConcurrentusingBlock:^(NSString*obj,NSUIntegeridx,BOOL*_Nonnullstop) {

obj = [NSStringstringWithFormat:@"_%@", obj];

[iosMutableArrayreplaceObjectAtIndex:idxwithObject:obj];

NSLog(@"%@", obj);

if([objisEqualToString:@"_I"]) {

*stop =YES;

}

}];

你可能感兴趣的:(OC遍历(官方推荐))