一 ) 数组便利那种方式效率更高 ,往数组里添加了10000个字符串,然后通过便利讲每个字符串到控制台输出
for (int i=0; i<10000; i++) {
NSString *string = @"111";
[self.array addObject:string];
}
01 for - in 便利10000次 耗时 2.555秒
for (NSString *string in self.array) {
NSLog(@"----%@",string);
}
02 for int i =0 ; i<self.array.count ; i++ 便利10000次 耗时 2.818秒
for (int i=0; i<self.array.count ; i++ ) {
NSLog(@"----%@",self.array[i]);
}
03 enumerateObjectsUsingBlock NSArray 提供的方法进行便利 耗时 3.348秒
[self.array enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
NSLog(@"----%@",obj);
}];
二 ) 对 NSDictionary 进行便利 ,往 dict 里边添加10000个元素,然后打印每个 object的值
01 根据 [dict allkeys] 便利所有key 取出对应的 value 耗时 2.223 秒
for (NSString *key in [self.dict allKeys]) {
id object = self.dict[key];
NSLog(@"----%@",object);
}
02 利用 NSDictionay 的 enumerateKeysAndObjectsUsingBlock 耗时 2.139 秒
[self.dict enumerateKeysAndObjectsUsingBlock:^(id _Nonnull key, id _Nonnull obj, BOOL * _Nonnull stop) {
NSLog(@"----%@",obj);
}];
03 利用枚举器便利 耗时 3.031 秒
NSEnumerator *enumerator = [self.dict keyEnumerator];
id object;
while (object =[enumerator nextObject]) {
id objectValue = self.dict[object];
NSLog(@"\n--%@ \n",objectValue);
}
04 利用系统的 enumerateKeysAndObjectsWithOptions 便利 1.168 秒
[self.dict enumerateKeysAndObjectsWithOptions:NSEnumerationConcurrent usingBlock:^(id _Nonnull key, id _Nonnull obj, BOOL * _Nonnull stop) {
NSLog(@"----%@",obj);
}];
好了,我是大兵布莱恩特,欢迎加入博主技术交流群,iOS 开发交流群
![QQ20180712-0.png](https://img.haomeiwen.com/i1155481/9b84a3a3fce64f61.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
网友评论