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

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

區分Java中的ArrayList和LinkedList

瀏覽:5日期:2022-08-30 11:24:01

一:ArrayList和LinkedList的大致區別如下:

1.ArrayList是實現了基于動態數組的數據結構,ArrayList實現了長度可變的數組,在內存中分配連續的空間。遍歷元素和隨機訪問元素的效率比較高

2.LinkedList基于鏈表的數據結構, 插入、刪除元素時效率比較高 故:【插入、刪除操作頻繁時,可使用LinkedList來提高效率】LinkedList提供對頭部和尾部元素進行添加和刪除操作的方法,插入/刪除第一個和最后一個效率比較高;

3:ArrayList和LinkedList都是List接口的實現,都存儲一組不唯一,有序(插入順序)的對象, 對元素進行添加、刪除等操作[ 即:List的性質]

4.對于隨機訪問get和set,ArrayList覺得優于LinkedList,因為LinkedList要移動指針。

5.對于新增和刪除操作add和remove,LinedList比較占優勢,因為ArrayList要移動數據。

6:LinkedList比ArrayList更占內存

eg:(代碼示例01)----ArrayList與LinkedLis的數據添加和查找耗時對比

import java.util.ArrayList;import java.util.LinkedList;import java.util.List;public class HFSD { static final int N=50000; //添加5000條數據 static long timeList(List list){ //添加數據所需時間 long start=System.currentTimeMillis(); Object o = new Object(); for(int i=0;i<N;i++) { list.add(0, o); } return System.currentTimeMillis()-start; } static long readList(List list){ //查找數據所需時間 long start=System.currentTimeMillis(); for(int i=0,j=list.size();i<j;i++){ } return System.currentTimeMillis()-start; } static List addList(List list){ Object o = new Object(); for(int i=0;i<N;i++) { list.add(0, o); } return list; } public static void main(String[] args) { System.out.println('ArrayList添加'+N+'條耗時:'+timeList(new ArrayList())); System.out.println('LinkedList添加'+N+'條耗時:'+timeList(new LinkedList())); List list1=addList(new ArrayList<>()); List list2=addList(new LinkedList<>()); System.out.println('ArrayList查找'+N+'條耗時:'+readList(list1)); System.out.println('LinkedList查找'+N+'條耗時:'+readList(list2)); }

區分Java中的ArrayList和LinkedList

從以上結果,我i們可以看出 ArrayList更適合讀取數據,linkedList更多的時候添加或刪除數據。

ArrayList:內部是使用可??長數組實現的,所以是用get和set方法是花費少數時間的,但是如果插入元素和刪除元素,除非插入和刪除的位置都在表末尾,否則代碼開銷會很大,因為里面需要數組的移動。

LinkedList:是使用雙鏈表實現的,所以get會非常消耗資源,除非位置離頭部很近。但是插入和刪除元素花費少數時間。

二:ArrayList和LinkedList的共有方法(即List的方法):

區分Java中的ArrayList和LinkedList

eg:(代碼示例02)----ArrayList代碼示例

package JIhekuangjia006.ArrayList;/** * 小豬類 */public class Pig { private String name; private String sex; public Pig(String name,String sex){ this.name=name; this.sex=sex; } public void setName(String name){ this.name=name; } public String getName(){ return name; } public void setSex(String sex){ this.sex=sex; } public String getSex(){ return sex; }}

package JIhekuangjia006.ArrayList;import java.util.*;/** * 使用ArrayList集合進行操作數據 */public class Test1 { public static void main(String[] args) { //1.存儲小豬信息 Pig xiaojia=new Pig('小佳','母');//索引為0 Pig xiaolong=new Pig('小龍','公');//索引為1 Pig jiajia=new Pig('佳佳','女');//索引為2 Pig longlong=new Pig('龍龍','男');//索引為3(與數組相同,從0開始) //為小豬排序 List list=new ArrayList(); //直接將元素添加排序 list.add(xiaojia); list.add(jiajia); list.add(xiaolong); //將龍龍添加到索引為2的位置 list.add(2,longlong); //list.add(jiajia);//List 接口存儲一組不唯一,有序(插入順序)的對象 //2.獲得小豬的總數 //通過list.size()方法獲取元素的個數 list.size(); System.out.println('小豬的總數為'+list.size()); //3.逐條打印小豬信息 //方法一:for循環與get()方法配合實現遍歷 for(int i=0;i<list.size();i++){ Pig center=(Pig)list.get(i);//因為list.get()的返回值為Object的類型,所以需要強轉為Pig的類型 System.out.println(center.getName()+','+center.getSex()); } //方法二:通過迭代器Iterator實現遍歷// Iterator it=list.iterator();// while (it.hasNext()){// Pig center=(Pig)it.next();// System.out.println(center.getName()+','+center.getSex());// } System.out.println('*********************************************************'); //4.刪除小豬信息 //刪除第一只小豬,小佳 list.remove(0);//與數組下標相對應 //刪除指定小豬,小龍 list.remove(xiaolong); //將剩下的小豬信息進行輸出 System.out.println('刪除之后還有'+list.size()+'只小豬,n分別是:'); for(int i=0;i<list.size();i++){ /** * Object get(int index)返回指定索引位置處的元素。取出的元素是Object類型, * 使用前需要進行強制類型轉換 */ Pig center=(Pig)list.get(i);//所以需要強轉為Pig的類型 System.out.println(center.getName()+','+center.getSex()); } System.out.println('*******************************************************'); //5.判斷集合中是否包含指定小豬 if (list.contains(xiaojia)){//使用list.contains()方法進行判斷 System.out.println('集合中有小佳'); }else{ System.out.println('集合中沒有小佳'); } }}

測試運行結果如下:

區分Java中的ArrayList和LinkedList

三:LinkedList的特有方法:

區分Java中的ArrayList和LinkedList

eg:(代碼示例03)----LinkedList代碼示例:

package JIhekuangjia006.LinkedList;/** * 小豬類 */public class Pig { private String name; //昵稱 private String sex; //性別 public Pig(String name,String sex){ this.name=name; this.sex=sex; } public void setName(String name){ this.name=name; } public String getName(){ return name; } public void setSex(String sex){ this.sex=sex; } public String getSex(){ return sex; }}

package JIhekuangjia006.LinkedList;import java.util.Iterator;import java.util.LinkedList;/** * 使用LinkedList集合操作數據 */public class Test2 { public static void main(String[] args) { //1.存儲小豬信息 Pig xiaojia=new Pig('小佳','母');//索引為0 Pig xiaolong=new Pig('小龍','公');//索引為1 Pig jiajia=new Pig('佳佳','女');//索引為2 Pig longlong=new Pig('龍龍','男');//索引為3(與數組相同,從0開始) //為小豬排序 LinkedList list=new LinkedList(); //直接將元素添加排序 list.add(xiaolong); list.add(longlong); list.addFirst(jiajia);//將佳佳添加到第一個位置 list.addLast(xiaojia);//將小龍添加到最后一個位置 //list.add(jiajia);//List 接口存儲一組不唯一,有序(插入順序)的對象 //2.獲得小豬的總數 //通過list.size()方法獲取元素的個數 list.size(); System.out.println('小豬的總數為'+list.size()); //3.逐條打印小豬的信息 //方法一:通過迭代器Iterator實現遍歷 Iterator it=list.iterator(); while (it.hasNext()){ Pig center=(Pig)it.next(); System.out.println(center.getName()+','+center.getSex()); } //方法二:for循環與get()方法配合實現遍歷// for(int i=0;i<list.size();i++){// Pig pig=(Pig)list.get(i);// System.out.println(pig.getName()+','+pig.getSex());// } System.out.println('************************************************'); //4. //獲取第一只小豬的信息 Pig center=(Pig)list.getFirst(); System.out.println('第一條狗狗信息是:'+center.getName()+','+center.getSex()); //獲取最后一只小豬的信息 Pig center1=(Pig)list.getLast(); System.out.println('最后一條狗狗信息是:'+center1.getName()+','+center1.getSex()); System.out.println('*****************************************************'); //5.刪除第一只小豬和最后一只小豬 list.removeFirst(); list.removeLast(); System.out.println('*****************************************************'); //6.輸出剩下小豬的信息 System.out.println('剩下還有'+list.size()+'只小豬,n分別是:'); for(int i=0;i<list.size();i++){ Pig pig=(Pig)list.get(i); System.out.println(pig.getName()+','+pig.getSex()); } //7.判斷集合中是否存在小佳 if(list.contains(xiaojia)){ System.out.println('集合中存在小佳'); }else{ System.out.println('集合中不存在小佳'); } }}

測試運行結果如下:

區分Java中的ArrayList和LinkedList

以上就是區分Java中的ArrayList和LinkedList的詳細內容,更多關于Java中ArrayList和LinkedList的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 楼承板-钢筋楼承板-闭口楼承板-无锡优贝斯楼承板厂 | 深圳市宏康仪器科技有限公司-模拟高空低压试验箱-高温防爆试验箱-温控短路试验箱【官网】 | 净化工程_无尘车间_无尘车间装修-广州科凌净化工程有限公司 | 郑州宣传片拍摄-TVC广告片拍摄-微电影短视频制作-河南优柿文化传媒有限公司 | 青岛美佳乐清洁工程有限公司|青岛油烟管道清洗|酒店|企事业单位|学校工厂厨房|青岛油烟管道清洗 插针变压器-家用电器变压器-工业空调变压器-CD型电抗器-余姚市中驰电器有限公司 | 利浦顿蒸汽发生器厂家-电蒸汽发生器/燃气蒸汽发生器_湖北利浦顿热能科技有限公司官网 | 消泡剂_水处理消泡剂_切削液消泡剂_涂料消泡剂_有机硅消泡剂_广州中万新材料生产厂家 | wika威卡压力表-wika压力变送器-德国wika代理-威卡总代-北京博朗宁科技 | 洁净棚-洁净工作棚-无菌室-净化工程公司_北京卫护科技有限公司 | 圆形振动筛_圆筛_旋振筛_三次元振动筛-河南新乡德诚生产厂家 | 打包箱房_集成房屋-山东佳一集成房屋有限公司| 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | 东莞工厂厂房装修_无尘车间施工_钢结构工程安装-广东集景建筑装饰设计工程有限公司 | 重庆轻质隔墙板-重庆安吉升科技有限公司 | 重庆LED显示屏_显示屏安装公司_重庆LED显示屏批发-彩光科技公司 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 电缆接头_防水接头_电缆防水接头 - 乐清市新豪电气有限公司 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 德国GMN轴承,GMN角接触球轴承,GMN单向轴承,GMN油封,GMN非接触式密封 | 活动策划,舞台搭建,活动策划公司-首选美湖上海活动策划公司 | CNC机加工-数控加工-精密零件加工-ISO认证厂家-鑫创盟 | 股票入门基础知识_股票知识_股票投资大师_格雷厄姆网 | SDG吸附剂,SDG酸气吸附剂,干式酸性气体吸收剂生产厂家,超过20年生产使用经验。 - 富莱尔环保设备公司(原名天津市武清县环保设备厂) | 液压升降货梯_导轨式升降货梯厂家_升降货梯厂家-河南东圣升降设备有限公司 | 河南正规膏药生产厂家-膏药贴牌-膏药代加工-修康药业集团官网 | 模具钢_高速钢_不锈钢-万利钢金属材料 | 耐压仪-高压耐压仪|徐吉电气| 私人别墅家庭影院系统_家庭影院音响_家庭影院装修设计公司-邦牛影音 | 二次元影像仪|二次元测量仪|拉力机|全自动影像测量仪厂家_苏州牧象仪器 | 上海平衡机-单面卧式动平衡机-万向节动平衡机-圈带动平衡机厂家-上海申岢动平衡机制造有限公司 | 桌上式超净工作台-水平送风超净工作台-上海康路仪器设备有限公司 | 预制围墙_工程预制围墙_天津市瑞通建筑材料有限公司 | 伸缩器_伸缩接头_传力接头-巩义市润达管道设备制造有限公司 | 万烁建筑设计院-建筑设计公司加盟,设计院加盟分公司,市政设计加盟 | 注浆压力变送器-高温熔体传感器-矿用压力传感器|ZHYQ朝辉 | 深圳公司注册-工商注册公司-千百顺代理记账公司 | 交流伺服电机|直流伺服|伺服驱动器|伺服电机-深圳市华科星电气有限公司 | 展厅设计公司,展厅公司,展厅设计,展厅施工,展厅装修,企业展厅,展馆设计公司-深圳广州展厅设计公司 | 安驭邦官网-双向万能直角铣头,加工中心侧铣头,角度头[厂家直销] 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 生物颗粒燃烧机-生物质燃烧机-热风炉-生物颗粒蒸汽发生器-丽水市久凯能源设备有限公司 | 水平筛厂家-三轴椭圆水平振动筛-泥沙震动筛设备_山东奥凯诺矿机 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 原色会计-合肥注册公司_合肥代理记账公司_营业执照代办 |