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;
}
}];