遍历方法比较
2016-05-28 15:01
197 查看
ForLoop
For - in
enumerateObjectsUsingBlock
enumerateObjectsWithOptions
enumerateKeysAndObjectsUsingBlock
进行速度比较后:
当只是遍历一个数组的时候使用For-in会比较快速, 推荐使用For-in遍历数组;
通过Value查询index的时候, 面对大量的数组推荐使用 enumerateObjectsWithOptions的并行方法;
当我们想遍历字典类型的时候, 推荐使用enumerateKeysAndObjectsUsingBlock。
另enumerateObjectsWithOptions(NSEnumerationConcurrent)和dispatch_apply(Concurrent)的遍历执行可以利用到多核cpu的优势(实验中在双核cpu上效率基本上x2);
遍历执行block会分配在多核cpu上执行(底层很可能就是gcd的并发queue),对于耗时的任务来说是很值得这么做的,而且在以后cpu升级成更多核心后不用改代码也可以享受带来的好处。
For - in
enumerateObjectsUsingBlock
enumerateObjectsWithOptions
enumerateKeysAndObjectsUsingBlock
进行速度比较后:
当只是遍历一个数组的时候使用For-in会比较快速, 推荐使用For-in遍历数组;
通过Value查询index的时候, 面对大量的数组推荐使用 enumerateObjectsWithOptions的并行方法;
当我们想遍历字典类型的时候, 推荐使用enumerateKeysAndObjectsUsingBlock。
另enumerateObjectsWithOptions(NSEnumerationConcurrent)和dispatch_apply(Concurrent)的遍历执行可以利用到多核cpu的优势(实验中在双核cpu上效率基本上x2);
遍历执行block会分配在多核cpu上执行(底层很可能就是gcd的并发queue),对于耗时的任务来说是很值得这么做的,而且在以后cpu升级成更多核心后不用改代码也可以享受带来的好处。
相关文章推荐
- 文件遍历排序函数
- Lua 学习笔记之C API 遍历 Table实现代码
- C#遍历文件夹后上传文件夹中所有文件错误案例分析
- C#中遍历Hashtable的4种方法
- Erlang中遍历取出某个位置的最大值代码
- C++实现图的邻接矩阵存储和广度、深度优先遍历实例分析
- C++实现图的邻接表存储和广度优先遍历实例分析
- 举例讲解C语言程序中对二叉树数据结构的各种遍历方式
- C++非递归队列实现二叉树的广度优先遍历
- php遍历目录方法小结
- 一个目录遍历函数
- php遍历删除整个目录及文件的方法
- PHP遍历文件夹与文件类及处理类用法实例
- PHP遍历XML文档所有节点的方法
- php中使用key,value,current,next和prev函数遍历数组的方法
- C#使用前序遍历、中序遍历和后序遍历打印二叉树的方法
- C#使用foreach遍历哈希表(hashtable)的方法
- php递归遍历多维数组的方法
- C#使用yield关键字让自定义集合实现foreach遍历的方法
- C#常见的几种集合 ArrayList,Hashtable,List<T>,Dictionary<K,V> 遍历方法对比