电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

通過實例解析Java List正確使用方法

瀏覽:145日期:2022-08-21 15:33:55

List是Java中比較常用的集合類,關于List接口有很多實現類,本文就來簡單介紹下其中幾個重點的實現ArrayList、LinkedList和Vector之間的關系和區別。

List

List 是一個接口,它繼承于Collection的接口。它代表著有序的隊列。當我們討論List的時候,一般都和Set作比較。

List中元素可以重復,并且是有序的(這里的有序指的是按照放入的順序進行存儲。如按照順序把1,2,3存入List,那么,從List中遍歷出來的順序也是1,2,3)。

Set中的元素不可以重復,并且是無序的(從set中遍歷出來的數據和放入順序沒有關系)。

下面是Java中的集合類的關系圖。從中可以大致了解集合類之間的關系

通過實例解析Java List正確使用方法java-collection-hierarchy

ArrayList、 LinkedList 和 Vector之間的區別

從上圖可以看出,ArrayList、 LinkedList 和 Vector都實現了List接口,是List的三種實現,所以在用法上非常相似。他們之間的主要區別體現在不同操作的性能上。后面會詳細分析。

ArrayList

ArrayList底層是用數組實現的,可以認為ArrayList是一個可改變大小的數組。隨著越來越多的元素被添加到ArrayList中,其規模是動態增加的。

LinkedList

LinkedList底層是通過雙向鏈表實現的。所以,LinkedList和ArrayList之前的區別主要就是數組和鏈表的區別。

數組中查詢和賦值比較快,因為可以直接通過數組下標訪問指定位置。

鏈表中刪除和增加比較快,因為可以直接通過修改鏈表的指針(Java中并無指針,這里可以簡單理解為指針。其實是通過Node節點中的變量指定)進行元素的增刪。

所以,LinkedList和ArrayList相比,增刪的速度較快。但是查詢和修改值的速度較慢。同時,LinkedList還實現了Queue接口,所以他還提供了offer(), peek(), poll()等方法。

Vector

Vector和ArrayList一樣,都是通過數組實現的,但是Vector是線程安全的。和ArrayList相比,其中的很多方法都通過同步(synchronized)處理來保證線程安全。

如果你的程序不涉及到線程安全問題,那么使用ArrayList是更好的選擇(因為Vector使用synchronized,必然會影響效率)。

二者之間還有一個區別,就是擴容策略不一樣。在List被第一次創建的時候,會有一個初始大小,隨著不斷向List中增加元素,當List認為容量不夠的時候就會進行擴容。Vector缺省情況下自動增長原來一倍的數組長度,ArrayList增長原來的50%。

ArrayList 和 LinkedList的性能對比

使用以下代碼對ArrayList和LinkedList中的幾種主要操作所用時間進行對比:

ArrayList<Integer> arrayList = new ArrayList<Integer>();LinkedList<Integer> linkedList = new LinkedList<Integer>();// ArrayList addlong startTime = System.nanoTime();for (int i = 0; i < 100000; i++) { arrayList.add(i);}long endTime = System.nanoTime();long duration = endTime - startTime;System.out.println('ArrayList add: ' + duration);// LinkedList addstartTime = System.nanoTime();for (int i = 0; i < 100000; i++) { linkedList.add(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('LinkedList add: ' + duration);// ArrayList getstartTime = System.nanoTime();for (int i = 0; i < 10000; i++) { arrayList.get(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('ArrayList get: ' + duration);// LinkedList getstartTime = System.nanoTime();for (int i = 0; i < 10000; i++) { linkedList.get(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('LinkedList get: ' + duration);// ArrayList removestartTime = System.nanoTime();for (int i = 9999; i >=0; i--) { arrayList.remove(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('ArrayList remove: ' + duration);// LinkedList removestartTime = System.nanoTime();for (int i = 9999; i >=0; i--) { linkedList.remove(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('LinkedList remove: ' + duration);

結果:

ArrayList add: 13265642LinkedList add: 9550057ArrayList get: 1543352LinkedList get: 85085551ArrayList remove: 199961301LinkedList remove: 85768810arraylist-vs-linkedlist1

通過實例解析Java List正確使用方法

他們的表現的差異是顯而易見的。在添加和刪除操作上LinkedList更快,但在查詢速度較慢。

如何選擇

如果涉及到多線程,那么就選擇Vector(當然,你也可以使用ArrayList并自己實現同步)。

如果不涉及到多線程就從LinkedList、ArrayList中選。 LinkedList更適合從中間插入或者刪除(鏈表的特性)。 ArrayList更適合檢索和在末尾插入或刪除(數組的特性)。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 二手色谱仪器,十万分之一分析天平,蒸发光检测器,电位滴定仪-湖北捷岛科学仪器有限公司 | BESWICK球阀,BESWICK接头,BURKERT膜片阀,美国SEL继电器-东莞市广联自动化科技有限公司 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 烟台金蝶财务软件,烟台网站建设,烟台网络推广 | 酒吧霸屏软件_酒吧霸屏系统,酒吧微上墙,夜场霸屏软件,酒吧点歌软件,酒吧互动游戏,酒吧大屏幕软件系统下载 | 复盛空压机配件-空气压缩机-复盛空压机(华北)总代理 | 大型低温冷却液循环泵-低温水槽冷阱「厂家品牌」京华仪器_京华仪器 | 酒店厨房设计_中央厨房设计_北京商用厨房设计公司-奇能商厨 | 权威废金属|废塑料|废纸|废铜|废钢价格|再生资源回收行情报价中心-中废网 | 南京精锋制刀有限公司-纵剪机刀片_滚剪机刀片_合金刀片厂家 | 合肥废气治理设备_安徽除尘设备_工业废气处理设备厂家-盈凯环保 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 | 代写标书-专业代做标书-商业计划书代写「深圳卓越创兴公司」 | 示波器高压差分探头-国产电流探头厂家-南京桑润斯电子科技有限公司 | 镀锌角钢_槽钢_扁钢_圆钢_方矩管厂家_镀锌花纹板-海邦钢铁(天津)有限公司 | 武汉画册印刷厂家-企业画册印刷-画册设计印刷制作-宣传画册印刷公司 - 武汉泽雅印刷厂 | 长沙广告公司_制作,长沙喷绘_发光字_招牌制作_长沙泓润广告官网 长城人品牌官网 | 合肥地磅_合肥数控切割机_安徽地磅厂家_合肥世佳电工设备有限公司 | 阁楼货架_阁楼平台_仓库仓储设备_重型货架_广州金铁牛货架厂 | 外贮压-柜式-悬挂式-七氟丙烷-灭火器-灭火系统-药剂-价格-厂家-IG541-混合气体-贮压-非贮压-超细干粉-自动-灭火装置-气体灭火设备-探火管灭火厂家-东莞汇建消防科技有限公司 | 智慧旅游_智慧景区_微景通-智慧旅游景区解决方案提供商 | 华中线缆有限公司-电缆厂|电缆厂家|电线电缆厂家 | 科客,主见不成见| 带锯机|木工带锯机圆木推台锯|跑车带锯机|河北茂业机械制造有限公司| | 环保袋,无纺布袋,无纺布打孔袋,保温袋,环保袋定制,环保袋厂家,环雅包装-十七年环保袋定制厂家 | 安徽免检低氮锅炉_合肥燃油锅炉_安徽蒸汽发生器_合肥燃气锅炉-合肥扬诺锅炉有限公司 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 水成膜泡沫灭火剂_氟蛋白泡沫液_河南新乡骏华消防科技厂家 | 车辆定位管理系统_汽车GPS系统_车载北斗系统 - 朗致物联 | Pos机办理_个人商户免费POS机申请-拉卡拉办理网 | 灰板纸、灰底白、硬纸板等纸品生产商-金泊纸业 | 电解抛光加工_不锈钢电解抛光_常州安谱金属制品有限公司 | 超声波清洗机_大型超声波清洗机_工业超声波清洗设备-洁盟清洗设备 | 仿古瓦,仿古金属瓦,铝瓦,铜瓦,铝合金瓦-西安东申景观艺术工程有限公司 | 航空障碍灯_高中低光强航空障碍灯_民航许可认证航空警示灯厂家-东莞市天翔航天科技有限公司 | 耳模扫描仪-定制耳机设计软件-DLP打印机-asiga打印机-fitshape「飞特西普」 | 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 宁夏活性炭_防护活性炭_催化剂载体炭-宁夏恒辉活性炭有限公司 | hdpe土工膜-防渗膜-复合土工膜-长丝土工布价格-厂家直销「恒阳新材料」-山东恒阳新材料有限公司 ETFE膜结构_PTFE膜结构_空间钢结构_膜结构_张拉膜_浙江萬豪空间结构集团有限公司 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 国际金融网_每日财经新资讯网 | 粘度计维修,在线粘度计,二手博勒飞粘度计维修|收购-天津市祥睿科技有限公司 |