A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 王运科 中级黑马   /  2012-4-24 11:03  /  1696 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

有以下两种方法遍历:   
public void list1(List<String> list)
        {
                long l1 = System.currentTimeMillis();
                for (String string : list)
                {
                        System.out.println(string);
                }
                System.out.println(System.currentTimeMillis() - l1);
        }
        public void list2(List<String> list)
        {
                long l1 = System.currentTimeMillis();
                Iterator<String> it = list.iterator();
                while (it.hasNext())
                {
                        String str = it.next();
                        System.out.println(str);
                }
                System.out.println(System.currentTimeMillis() - l1);
        }
推荐使用第二种方式,性能比第一种快。
奥秘在于应用程序自身不维护遍历集合的"指针",所有的内部状态(如当前元素位置,是否有下一个元素)都由Iterator来维护,而这个Iterator由集合类通过工厂方法生成,因此,它知道如何遍历整个集合。应用程序不直接和集合类打交道,它总是控制Iterator,向它发送"向前","向后","取当前元素"的命令,就可以间接遍历整个集合。

1 个回复

倒序浏览
姿势贴,顶个
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马