码迷,mamicode.com
首页 > 移动开发 > 详细

Android中List循环遍历性能对照

时间:2017-07-27 21:28:28      阅读:230      评论:0      收藏:0      [点我收藏+]

标签:google   lin   oid   net   性能   down   line   apple   clip   

在android开发中仅仅要是列表式风格界面我们差点儿都须要用到List来存放数据,在数量非常少的List的话差点儿不论什么一种循环遍历方式总体性能都无区别。可是当我们遇到数据量稍大的时候有必要考虑用哪种方式写起来比較高性能。
常见的有下面三种:
第一种

for (String s : tests) {
    // ....
}

另外一种

int size = tests.size();
for (int i = 0; i < size; i++) {
    tests.get(i);
}

第三种

Iterator<String> it = tests.iterator();
    while(it.hasNext()) {
        it.next();
    }

採用以上三种在数据量少于等于100的情况下差点儿输出时间都为0,当在1000左右的时候第三种略微慢在1ms左右<可能在当时的环境原因>能够说三种方式也是没区别,当数据量在10000左右我们就能看到区别了第一种和第三种差点儿相同要4ms而另外一种仅仅要2ms,当数据量在100000左右的话第一种差点儿相同要40ms,另外一种17ms,第三种33ms。

技术分享

声明:以上环境在MacBook Pro -> Eclipse -> Android5.0 -> Nexus5手机环境下的測试结果,Google下面资料显示在非JIT的情况下事实上第一种是最快的,可是在Android环境下还是採用另外一种才是最佳性能选择。

Android中List循环遍历性能对照

标签:google   lin   oid   net   性能   down   line   apple   clip   

原文地址:http://www.cnblogs.com/blfbuaa/p/7246890.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!