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

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

Java中List集合去重方法以及效率對比

瀏覽:79日期:2022-08-14 18:21:13

List集合相信大家在開發過程中幾乎都會用到。有時候難免會遇到集合里的數據是重復的,需要進行去除。然而,去重方式有好幾種方式,你用的是哪種方式呢?去重方式效率是否是最高效、最優的呢?今天就給大家講解一下List集合去重的常見及常用的四種方式。

01

實現思路:使用兩個for循環遍歷集合所有元素,然后進行判斷是否有相同元素,如果有,則去除。這種方式是大部分最先想到的,也是最簡單的實現方式。其中,這種方式可以保證List集合原來的順序不變。

代碼實現:

/*** notes:使用兩個for循環實現List去重* @param list* @return*/public static List repeatListWayOne(List<String> list){ for(int i = 0;i < list.size();i++){ for(int j = i+1;j < list.size();j++){ if(list.get(i).equals(list.get(j))){ list.remove(j); } } } return list;}

02

實現思路:我們知道HashSet實現了Set接口,不允許出現重復元素。可以基于這個想法,把List集合所有元素存入HashSet對象,接著把List集合元素全部清空,最后把HashSet對象元素全部添加至List集合中,這樣就可以保證不出現重復元素。而HashSet有一個構造函數,在初始化時可以直接添加元素。其中,HashSet不能保證順序不變,所以此方式不能保證List集合原來的順序不變。

代碼實現:

/*** notes:使用HashSet實現List去重* @param list* @return*/public static List repeatListWayTwo(List<String> list){ //初始化HashSet對象,并把list對象元素賦值給HashSet對象 HashSet set = new HashSet(list); //把List集合所有元素清空 list.clear(); //把HashSet對象添加至List集合 list.addAll(set); return list;}

03

實現思路:TreeSet集合也是實現Set接口,是一個有序的,并且無重復元素集合。同理,我們可以根據上面方式二的思想進行去重。其中,去重后的List集合可以保證和原來的順序一致。

代碼實現:

/*** notes:使用TreeSet實現List去重* @param list* @return*/public static List repeatListWayThird(List<String> list){ //初始化TreeSet對象,并把list對象元素賦值給TreeSet對象 TreeSet set = new TreeSet(list); //把List集合所有元素清空 list.clear(); //把TreeSet對象添加至List集合 list.addAll(set); return list;}

04

實現思路:利用List集合contains方法循環遍歷,先創建新的List集合,接著循環遍歷原來的List集合,判斷新集合是否包含有舊集合,如果有,則不添加至新集合,否則添加。最后,把舊集合清空,把新集合元素賦值給舊集合。

代碼實現:

/*** notes:利用List集合contains方法循環遍歷去重* @param list* @return*/public static List repeatListWayFourth(List<String> list){ //新建新List集合,用于存放去重后的元素 List<String> newList = new ArrayList<String>(); //循環遍歷舊集合元素 for(int i = 0; i < list.size(); i++ ){ //判斷新集合是否包含有,如果不包含有,則存入新集合中 boolean isContains = newList.contains(list.get(i)); if(!isContains){ newList.add(list.get(i)); } } //把List集合所有元素清空 list.clear(); //把新集合元素添加至List集合 list.addAll(newList); return list;}

上面給大家介紹了四種List集合去重方式。那么,哪種方式效率是最好的呢?下面就演示一下進行對比。

為了演示方式,隨機生成0-500之間的20000個整數字符串,并存入List集合,并在相應代碼打印相關時間進行對比。其中,隨機生成List集合代碼如下:

/*** 隨機生成0-500之間的20000個整數字符串,并存入List集合* @return*/public static List<String> getRandomList(){ List<String> list = new ArrayList<String>(); //隨機生成20000個整數字符串 for(int i = 1; i <= 20000; i++){ //任意取[0,500)之間整數,其中0可以取到,500取不到 int number = new Random().nextInt(500); String number_str = 'geshan'+number; list.add(number_str); } return list;}

為了保證List集合元素一致,創建四個List集合,分別對應List去重方式。效率對比代碼如下:

public static void main(String[] args){ //隨機生成0-500之間的1000個整數字符串List集合 List<String> list = getRandomList(); //為了演示四種方式效率,創建四個List集合,保證List集合元素一致 //方式一List集合 List<String> oneList = new ArrayList<>(); oneList.addAll(list); //方式二List集合 List<String> twoList = new ArrayList<>(); twoList.addAll(list); //方式三List集合 List<String> thirdList = new ArrayList<>(); thirdList.addAll(list); //方式四List集合 List<String> fourthList = new ArrayList<>(); fourthList.addAll(list); System.out.println('方式一:使用兩個for循環實現List去重'); System.out.println('原來集合大小:'+oneList.size()+',集合元素>>'+oneList); Date oneDateBegin = new Date(); repeatListWayOne(oneList); System.out.println('集合去重大小:'+oneList.size()+',集合元素>>'+oneList); Date oneDateEnd = new Date(); System.out.println('去重所需時間:'+(oneDateEnd.getTime()-oneDateBegin.getTime())+'毫秒'); System.out.println('方式二:使用HashSet實現List去重'); System.out.println('原來集合大小:'+twoList.size()+',集合元素>>'+twoList); Date twoDateBegin = new Date(); repeatListWayTwo(twoList); System.out.println('集合去重大小:'+twoList.size()+',集合元素>>'+twoList); Date twoDateEnd = new Date(); System.out.println('去重所需時間:'+(twoDateEnd.getTime()-twoDateBegin.getTime())+'毫秒'); System.out.println('方式三:使用TreeSet實現List去重'); System.out.println('原來集合大小:'+thirdList.size()+',集合元素>>'+thirdList); Date thirdDateBegin = new Date(); repeatListWayThird(thirdList); System.out.println('集合去重大小:'+thirdList.size()+',集合元素>>'+thirdList); Date thirdDateEnd = new Date(); System.out.println('去重所需時間:'+(thirdDateEnd.getTime()-thirdDateBegin.getTime())+'毫秒'); System.out.println('方式四:利用List集合contains方法循環遍歷去重'); System.out.println('原來集合大小:'+fourthList.size()+',集合元素>>'+fourthList); Date fourthDateBegin = new Date(); repeatListWayFourth(fourthList); System.out.println('集合去重大小:'+fourthList.size()+',集合元素>>'+fourthList); Date fourthDateEnd = new Date(); System.out.println('去重所需時間:'+(fourthDateEnd.getTime()-fourthDateBegin.getTime())+'毫秒');}

多次運行結果如下:

第一次四種方式運行時間如下:223、10、16、30;

第二次四種方式運行時間如下:164、10、17、43;

第三次四種方式運行時間如下:164、9、16、37;

綜合代碼及運行時間對比,方式二是最好的去重方式,代碼最簡潔、耗時最短,但是順序可能會被打亂,如果需要按原順序,方式三比較好。你平時List集合去重,方式用對了嗎?

總結

到此這篇關于Java中List集合去重方法以及效率對比的文章就介紹到這了,更多相關java List集合去重效率內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 全温度恒温培养摇床-大容量-立式-远红外二氧化碳培养箱|南荣百科 | 工程管道/塑料管材/pvc排水管/ppr给水管/pe双壁波纹管等品牌管材批发厂家-河南洁尔康建材 | 杭州火蝠电商_京东代运营_拼多多全托管代运营【天猫代运营】 | 江西自考网-江西自学考试网| 除湿机|工业除湿机|抽湿器|大型地下室车间仓库吊顶防爆除湿机|抽湿烘干房|新风除湿机|调温/降温除湿机|恒温恒湿机|加湿机-杭州川田电器有限公司 | 不锈钢丸厂家,铝丸,铸钢丸-淄博智源铸造材料有限公司 | 气动机械手-搬运机械手-气动助力机械手-山东精瑞自动化设备有限公司 | 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | CPSE安博会| 【直乐】河北石家庄脊柱侧弯医院_治疗椎间盘突出哪家医院好_骨科脊柱外科专业医院_治疗抽动症/关节病骨伤权威医院|排行-直乐矫形中医医院 | 广东风淋室_广东风淋室厂家_广东风淋室价格_广州开源_传递窗_FFU-广州开源净化科技有限公司 | 高速龙门架厂家_监控杆_多功能灯杆_信号灯杆_锂电池太阳能路灯-鑫世源照明 | 红外光谱仪维修_二手红外光谱仪_红外压片机_红外附件-天津博精仪器 | 杭州荣奥家具有限公司-浙江办公家具,杭州办公家具厂 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | 探鸣起名网-品牌起名-英文商标起名-公司命名-企业取名包满意 | 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 英国公司注册-新加坡公司注册-香港公司开户-离岸公司账户-杭州商标注册-杭州优创企业 | 生物制药洁净车间-GMP车间净化工程-食品净化厂房-杭州波涛净化设备工程有限公司 | 南京精锋制刀有限公司-纵剪机刀片_滚剪机刀片_合金刀片厂家 | 天津次氯酸钠酸钙溶液-天津氢氧化钠厂家-天津市辅仁化工有限公司 | 【甲方装饰】合肥工装公司-合肥装修设计公司,专业从事安徽办公室、店面、售楼部、餐饮店、厂房装修设计服务 | 房车价格_依维柯/大通/东风御风/福特全顺/江铃图片_云梯搬家车厂家-程力专用汽车股份有限公司 | 书信之家_书信标准模板范文大全 最新范文网_实用的精品范文美文网 | 合肥展厅设计-安徽展台设计-合肥展览公司-安徽奥美展览工程有限公司 | 正压送风机-多叶送风口-板式排烟口-德州志诺通风设备 | 石家庄网站建设|石家庄网站制作|石家庄小程序开发|石家庄微信开发|网站建设公司|网站制作公司|微信小程序开发|手机APP开发|软件开发 | 超声波破碎仪-均质乳化机(供应杭州,上海,北京,广州,深圳,成都等地)-上海沪析实业有限公司 | 高考志愿规划师_高考规划师_高考培训师_高报师_升学规划师_高考志愿规划师培训认证机构「向阳生涯」 | 工业铝型材-铝合金电机壳-铝排-气动执行器-山东永恒能源集团有限公司 | 泵阀展|阀门展|水泵展|流体机械展 -2025上海国际泵管阀展览会flowtech china | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 | 银川美容培训-美睫美甲培训-彩妆纹绣培训-新娘化妆-学化妆-宁夏倍莱妮职业技能培训学校有限公司 临时厕所租赁_玻璃钢厕所租赁_蹲式|坐式厕所出租-北京慧海通 | 江西自考网 | 苏州伊诺尔拆除公司_专业酒店厂房拆除_商场学校拆除_办公楼房屋拆除_家工装拆除拆旧 | 快干水泥|桥梁伸缩缝止水胶|伸缩缝装置生产厂家-广东广航交通科技有限公司 | 游泳池设计|设备|配件|药品|吸污机-东莞市太平洋康体设施有限公司 | 智慧水务|智慧供排水利信息化|水厂软硬件系统-上海敢创 | 不锈钢拉手厂家|浴室门拉手厂家|江门市蓬江区金志翔五金制品有限公司 | 广东燎了网络科技有限公司官网-网站建设-珠海网络推广-高端营销型外贸网站建设-珠海专业h5建站公司「了了网」 | 考试试题_试卷及答案_诗词单词成语 - 优易学 |