java中对集合对象list的几种循环访问总结 Java中迭代列表中数据时几种循环写法的效率比较

java\u4e2d\u5bf9\u96c6\u5408\u5bf9\u8c61list\u7684\u51e0\u79cd\u5faa\u73af\u8bbf\u95ee

//1\u3001for\u5faa\u73af\uff0c\u53ef\u4ee5\u5199\u6210\u4ee5\u4e0b\u51e0\u79cdfor(int i=0;ilist.size()-1){break;}}//while \u5199\u6cd5\u5927\u540c\u5c0f\u5f02\uff0c\u90fd\u662f\u4e0d\u60f3\u5faa\u73af\u7684\u65f6\u5019\u5728\u6761\u4ef6\u4e2d\u6216\u62ec\u53f7\u4e2d\u53bb\u4e2d\u65ad

Java\u4e2d\u7ecf\u5e38\u4f1a\u7528\u5230\u8fed\u4ee3\u5217\u8868\u6570\u636e\u7684\u60c5\u51b5\uff0c\u672c\u6587\u9488\u5bf9\u51e0\u79cd\u5e38\u7528\u7684\u5199\u6cd5\u8fdb\u884c\u6548\u7387\u6bd4\u8f83\u3002\u867d\u7136\u7f51\u4e0a\u5df2\u7ecf\u6709\u4e86\u7c7b\u4f3c\u7684\u6587\u7ae0\uff0c\u4f46\u662f\u5bf9\u4ed6\u4eec\u7684\u7ed3\u8bba\u5e76\u4e0d\u8ba4\u540c\u3002\u5e38\u89c1\u7684\u5b9e\u73b0\u65b9\u6cd5\uff1a1.for\u5faa\u73af\uff1afor(int i = 0; i 0) 4.\u8fed\u4ee3\uff1aObject iter = list.iterator(); while(iter.hasNext()) { iter.next(); }\u6d4b\u8bd5\u4ee3\u7801\uff1a \u9488\u5bf9\u4ee5\u4e0a\u51e0\u79cd\u65b9\u6cd5\u7f16\u5199\u7684\u6d4b\u8bd5\u4ee3\u7801\u3002 public static void main(String[] args) { List list = new ArrayList(); int runTime = 1000;//\u6267\u884c\u6b21\u6570 for (int i = 0; i < 1000 * 1000; i++) { list.add(i); } int size = list.size(); long currTime = System.currentTimeMillis();//\u5f00\u59cb\u5206\u6790\u524d\u7684\u7cfb\u7edf\u65f6\u95f4 //\u57fa\u672c\u7684for for(int j = 0; j < runTime; j++) { for (int i = 0; i < size; i++) { list.get(i); } } long time1 = System.currentTimeMillis(); //foreach for(int j = 0; j < runTime; j++) { for (Integer integer : list) { } } long time2 = System.currentTimeMillis(); for(int j = 0; j < runTime; j++) { //while int i = 0 ; while(i < size){ list.get(i++); } } long time3 = System.currentTimeMillis(); for(int j = 0; j < runTime; j++) {//\u666e\u901afor\u5faa\u73af for (int i = 0; i < list.size(); i++) { list.get(i); } } long time4 = System.currentTimeMillis(); for(int j = 0; j < runTime; j++) {//\u8fed\u4ee3 Iterator iter = list.iterator(); while(iter.hasNext()) { iter.next(); } } long time5 = System.currentTimeMillis(); long time = time1 - currTime ; System.out.print("use for:" + time); time = time2 - time1; System.out.print("\tuse foreach:" + time); time = time3 - time2; System.out.print("\tuse while:" + time); time = time4 - time3; System.out.print("\tuse for2:" + time); time = time5 - time4; System.out.print("\tuse iterator:" + time); System.out.println(); }\u8f93\u51fa\u7ed3\u679c\uff08JDK1.6\uff09\uff1a1.use for:8695 use foreach:17091 use while:6867 use for2:7741 use iterator:141442.use for:8432 use foreach:18126 use while:6905 use for2:7893 use iterator:139763.use for:8584 use foreach:17177 use while:6875 use for2:7707 use iterator:14345\u7ed3\u8bba\uff1a1.\u9488\u5bf9\u5217\u8868\u7684 foreach\u7684\u6548\u7387\u662f\u6700\u4f4e\uff1a\u8017\u65f6\u662f\u666e\u901afor\u5faa\u73af\u76842\u500d\u4ee5\u4e0a\u3002\u4e2a\u4eba\u7406\u89e3\u5b83\u7684\u5b9e\u73b0\u5e94\u8be5\u548citerator\u76f8\u4f3c\u30022. list.size()\u7684\u5f00\u9500\u5f88\u5c0f\uff1alist.size()\u6b21\u6570\u591a\u5c11\u5bf9\u6548\u7387\u57fa\u672c\u6ca1\u6709\u5f71\u54cd\u3002\u67e5\u770bArrayList\u7684\u5b9e\u73b0\u5c31\u4f1a\u53d1\u73b0\uff0csize()\u65b9\u6cd5\u7684\u53ea\u662f\u8fd4\u56de\u4e86\u5bf9\u8c61\u5185\u7684\u957f\u5ea6\u5c5e\u6027\uff0c\u5e76\u6ca1\u6709\u5176\u5b83\u8ba1\u7b97\uff0c\u6240\u4ee5\u53ea\u5b58\u5728\u51fd\u6570\u8c03\u7528\u7684\u5f00\u9500\u3002\u5bf9\u6570\u7ec4\u7684\u6d4b\u8bd5\uff1a\u5c06\u4ee3\u7801\u4e2d\u7684\u5217\u8868list\u6362\u505a\u6570\u7ec4\u518d\u8fdb\u884c\u6d4b\u8bd5\uff08iterator\u4e0d\u9002\u7528\uff09\uff0c\u53d1\u73b0\u8017\u65f6\u57fa\u672c\u4e3a0\u3002\u8bf4\u660e\uff1a3. \u5217\u8868\u7684get()\u65b9\u6cd5\u5f00\u9500\u4e0d\u5c11\u5e94\u8be5\u4e3b\u8981\u662f\u68c0\u6d4b\u6570\u636e\u5408\u6cd5\u6027\u65f6\u4ea7\u751f\u7684\u3002\u5c06\u6267\u884c\u6b21\u6570\u589e\u52a0100\u4e07\u500d\uff0c\u8fd9\u65f6\u53ef\u4ee5\u770b\u51fa\u7ed3\u679c\u57fa\u672c\u76f8\u7b49\uff0c\u5e76\u6ca1\u6709\u660e\u663e\u7684\u5dee\u5f02\u3002\u8bf4\u660e\uff1a4. \u6570\u7ec4length\u4e5f\u6ca1\u6709\u5f00\u9500\u53ef\u89c1\u6570\u7ec4\u957f\u5ea6\u5e76\u4e0d\u662f\u6bcf\u6b21\u6267\u884c\u7684\u65f6\u5019\u90fd\u8981\u8ba1\u7b97\u7684\u3002\u8054\u60f3\u4e00\u4e0bJava\u521b\u5efa\u6570\u7ec4\u7684\u65f6\u5019\u8981\u6c42\u5fc5\u987b\u6307\u5b9a\u6570\u7ec4\u7684\u957f\u5ea6\uff0c\u7f16\u8bd1\u5904\u7406\u7684\u65f6\u5019\u663e\u7136\u6ca1\u6709\u628a\u8fd9\u4e2a\u503c\u629b\u5f03\u6389\u3002\u7f51\u4e0a\u6709\u4e00\u7bc7\u7c7b\u4f3c\u7684\u6587\u7ae0\uff0c\u5b83\u5c45\u7136\u5f97\u51fa\u4e86\u4e00\u4e2aforeach\u6267\u884c\u6548\u7387\u6700\u9ad8\u7684\u7ed3\u8bba\u3002

List一共有三种遍历方法,如下:

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class Main {
    public static void main(String[] args) {
        List<Integer> list = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            list.add(i);
        }

        //for循环遍历
        for (int i = 0, size = list.size(); i < size; i++) {
            System.out.println(list.get(i));
        }

        //iterator迭代器遍历
        Iterator<Integer> it = list.iterator();
        while (it.hasNext()) {
            System.out.println(it.next());
        }

        //foreach循环
        for (Integer i : list) {
            System.out.println(i);
        }
    }
}

数据元素是怎样在内存中存放的?

主要有2种存储方式:

1、顺序存储,Random Access(Direct Access):

这种方式,相邻的数据元素存放于相邻的内存地址中,整块内存地址是连续的。可以根据元素的位置直接计算出内存地址,直接进行读取。读取一个特定位置元素的平均时间复杂度为O(1)。正常来说,只有基于数组实现的集合,才有这种特性。Java中以ArrayList为代表。

2、链式存储,Sequential Access:

这种方式,每一个数据元素,在内存中都不要求处于相邻的位置,每个数据元素包含它下一个元素的内存地址。不可以根据元素的位置直接计算出内存地址,只能按顺序读取元素。读取一个特定位置元素的平均时间复杂度为O(n)。主要以链表为代表。Java中以LinkedList为代表。

每个遍历方法的实现原理是什么?

1、传统的for循环遍历,基于计数器的:

遍历者自己在集合外部维护一个计数器,然后依次读取每一个位置的元素,当读取到最后一个元素后,停止。主要就是需要按元素的位置来读取元素。

2、迭代器遍历,Iterator:

每一个具体实现的数据集合,一般都需要提供相应的Iterator。相比于传统for循环,Iterator取缔了显式的遍历计数器。所以基于顺序存储集合的Iterator可以直接按位置访问数据。而基于链式存储集合的Iterator,正常的实现,都是需要保存当前遍历的位置。然后根据当前位置来向前或者向后移动指针。

3、foreach循环遍历:

根据反编译的字节码可以发现,foreach内部也是采用了Iterator的方式实现,只不过Java编译器帮我们生成了这些代码。

各遍历方式的适用于什么场合?

1、传统的for循环遍历,基于计数器的:

顺序存储:读取性能比较高。适用于遍历顺序存储集合。

链式存储:时间复杂度太大,不适用于遍历链式存储的集合。

2、迭代器遍历,Iterator:

顺序存储:如果不是太在意时间,推荐选择此方式,毕竟代码更加简洁,也防止了Off-By-One的问题。

链式存储:意义就重大了,平均时间复杂度降为O(n),还是挺诱人的,所以推荐此种遍历方式。

3、foreach循环遍历:

foreach只是让代码更加简洁了,但是他有一些缺点,就是遍历过程中不能操作数据集合(删除等),所以有些场合不使用。而且它本身就是基于Iterator实现的,但是由于类型转换的问题,所以会比直接使用Iterator慢一点,但是还好,时间复杂度都是一样的。所以怎么选择,参考上面两种方式,做一个折中的选择。



  • java list鎬庝箞鐢?
    绛旓細鍦JAVA涓锛屾兂瑕佹妸涓涓list涓鐨勫唴瀹规坊鍔犺嚦鍙︿竴涓猯ist涓紝鏈変袱绉嶆柟娉曪細閲囩敤寰幆鐨勬柟娉曘傞氳繃寰幆绗竴涓狝rrayList锛岀劧鍚庨氳繃姣忓惊鐜竴娆$殑鏂瑰紡锛屽皢鍊艰祴鍊肩粰鍙︿竴涓狝rrayList銆傚叿浣撲唬鐮佸疄鐜板涓嬶細2.閲囩敤ArrayList鑷甫鐨刟ddAll()鏂规硶銆俛ddAll()鏂规硶鏄氳繃浼犲叆鏁翠竴涓狶ist锛屽皢姝List涓鐨勬墍鏈夊厓绱犲姞鍏ュ埌鏂扮殑List涓紝...
  • java鎬庝箞鍚堝苟list瀵硅薄闆嗗悎
    绛旓細绗竴閲嶅惊鐜 鍊掑簭寰幆锛岀浜岄噸寰幆杩欎釜list涓鎵撅紝鎵惧埌灏卞悎骞鐨绗竴閲嶅惊鐜暟鎹腑锛屽垹闄よ繖涓暟鎹俧or(int i = list.size(); i >=0; i--) { User user = (User)list.get(i);User temp;for(int j = 0; j < list.size(); j ++) { if(user.get("time").equals(temp.get("time")...
  • Java濡備綍鑾峰彇List鐨鏌愪竴涓瀵硅薄鐨鏌愪竴鏉″厓绱?
    绛旓細list鍙互鐩存帴鑾峰彇浣嶇疆椤圭殑鍏冪礌list.get(index);杩欓噷鐨刬ndex灏辨槸浣嶇疆鍙栧艰寖鍥存槸锛0~list.size() - 1锛夎屼綘鎯宠幏鍙杣serlist涓鏈鍚庝竴涓瀵硅薄鐨User鐨刵ame锛屽彲浠 String name = userlist.get(userlist.size() - 1).getName();
  • Java涓鏈変竴涓list闆嗗悎,閲岄潰鏀句簡濂藉瀵硅薄,鎴戞兂閫氳繃瀵硅薄鐨涓や釜灞炴...
    绛旓細鍦ㄤ綘鐨绫閲岄潰閲嶅啓compareto鏂规硶锛岀敤浣犵殑閭d袱涓睘鎬ф潵鍒ゆ柇姣旇緝鏍囧噯銆傦紙浣犵殑绫婚渶瑕佸厛瀹炵幇comparable鎺ュ彛锛
  • JAVA涓鐨List鐨浣跨敤
    绛旓細鏇挎崲鍏冪礌锛堟浛鎹㈡帀鎸囧畾涓嬫爣鐨勫厓绱狅級锛list.set(index,e);鍙栧嚭鍏冪礌锛歭ist.get(index);娓呯┖闆嗗悎锛歭ist.clear();鍒ゆ柇闆嗗悎涓槸鍚﹀瓨鍦ㄦ煇涓厓绱狅紙瀛樺湪杩斿洖true锛屼笉瀛樺湪杩斿洖false锛夛細list.contains(e);瀵规瘮涓や釜闆嗗悎涓殑鎵鏈夊厓绱狅細涓や釜瀵硅薄涓瀹氱浉绛夛細list.equals(list2);涓や釜瀵硅薄涓嶄竴瀹氱浉绛夛細list.hashCode() =...
  • java 鏈夊摢浜闆嗗悎
    绛旓細Java涓殑闆嗗悎涓昏鏈変互涓嬪嚑绉嶏細1. List锛堝垪琛級List鏄湁搴忕殑闆嗗悎锛屽彲浠ュ寘鍚噸澶嶇殑鍏冪礌銆傚畠涓昏鏈変袱绉嶅疄鐜版柟寮忥細ArrayList鍜孡inkedList銆侫rrayList鏄熀浜庢暟缁勫疄鐜扮殑锛屾煡璇㈡晥鐜囬珮浣嗘彃鍏ュ拰鍒犻櫎鏁堢巼浣庯紱LinkedList鏄熀浜庨摼琛ㄥ疄鐜扮殑锛屾彃鍏ュ拰鍒犻櫎鏁堢巼楂樹絾鏌ヨ鏁堢巼浣庛2. Set锛堥泦鍚堬級Set鏄竴绉嶄笉鍖呭惈閲嶅鍏冪礌鐨勯泦鍚堛
  • 鍦java涓璴ist瀵硅薄鎬庝箞瀹氫箟
    绛旓細闆嗗悎涓殑list鏄帴鍙o紝鐢ㄥ瓙绫诲畾涔瀵硅薄锛屽List<E> list=new ArrayList<E>()
  • java涓璴ist闆嗗悎stream娴佹庝箞鎶婃暟鎹10涓竴鍒嗙粍
    绛旓細java涓璴ist闆嗗悎stream娴佹妸鏁版嵁10涓竴鍒嗙粍姝ラ濡備笅锛1銆侀鍏堜娇鐢╯ummingDouble鍜宎veragingDouble鏉ュ疄鐜癉oublesummingScore=students.stream().collect(Collectors.summingDouble(Student锛歡etScore))锛汥oubleaveragingScore=students.stream().collect(Collectors.averagingDouble(Student锛氾細getScore))锛2銆佷娇鐢...
  • java鐨刲ist闆嗗悎濡備綍鏍规嵁瀵硅薄涓鐨勬煇涓瓧娈垫帓搴
    绛旓細涓嬮潰鐨勪唬鐮佹槸鏍规嵁瀛︾敓骞撮緞鎺掑簭瀛︾敓list 鐨涓涓緥瀛愶細import java.util.ArrayList;import java.util.List;class Student {private String name;private int age;public Student(String name, int age) {this.name = name;this.age = age;}public String getName() {return name;}public void setName(...
  • JAVA濡備綍鏍规嵁List涓璞鐨勫睘鎬ц繘琛屽璞℃帓搴(姹熸箹鏁戞!)
    绛旓細鏈杩戣繖涔堝浜洪棶鎺掑簭鐨勯棶棰樺晩锛岄兘蹇洖绛旇吇浜嗭紝浣犲彲浠ュ厛鎼滀竴鎼滅湅鐪嬪埆鐨勭綉绔欐湁娌℃湁锛屼笉杩囨棦鐒堕兘鍥炵瓟浜嗭紝鎴戝氨浼颁笖鍐嶅彂浜涗唬鐮佸惂锛岃繖閲屽彧鐢⊿tring鐨凩ist鎺掑簭锛屽鏋滅敤鍒板鏉鐨勫璞浣犺嚜宸辨噦寰楀彉閫氬惂 public class SortList {private static DateFormat df = new SimpleDateFormat("yyyy-MM-dd");public static...
  • 扩展阅读:比较开放的社交软件 ... 黑马java视频 ... 免费视频私聊 ... java实现在线播放 ... 1v1视频聊天指挥 ... deskry在线匿名聊天一对一 ... www.imomoe.net ... 免费源码网站 ... javascript高级视频 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网