首页 > 其他分享 >37、list与Set区别

37、list与Set区别

时间:2023-05-17 21:44:45浏览次数:47  
标签:Set list 元素 37 Collection 插入 List

(1)List简介

实际上有两种List:一种是基本的ArrayList,其优点在于随机访问元素,另一种是LinkedList,它并不是为快速随机访问设计的,而是快速的插入或删除。
ArrayList:由数组实现的List。允许对元素进行快速随机访问,但是向List中间插入与移除元素的速度很慢。
LinkedList :对顺序访问进行了优化,向List中间插入与删除的开销并不大。随机访问则相对较慢。
还具有下列方 法:addFirst(), addLast(), getFirst(), getLast(), removeFirst() 和 removeLast(), 这些方法 (没有在任何接口或基类中定义过)使得LinkedList可以当作堆栈、队列和双向队列使用。

(2)Set简介

Set具有与Collection完全一样的接口,因此没有任何额外的功能。实际上Set就是Collection,只是行为不同。这是继承与多态思想的典型应用:表现不同的行为。Set不保存重复的元素(至于如何判断元素相同则较为负责)

Set : 存入Set的每个元素都必须是唯一的,因为Set不保存重复元素。加入Set的元素必须定义equals()方法以确保对象的唯一性。Set与Collection有完全一样的接口。Set接口不保证维护元素的次序。
HashSet:为快速查找设计的Set。存入HashSet的对象必须定义hashCode()。
TreeSet: 保存次序的Set, 底层为树结构。使用它可以从Set中提取有序的序列。

(3)list与Set区别

① List,Set都是继承自Collection接口

② List特点:元素有放入顺序,元素可重复 ,Set特点:元素无放入顺序,元素不可重复,重复元素会覆盖掉,(元素虽然无放入顺序,但是元素在set中的位置是有该元素的HashCode决定的,其位置其实是固定的,加入Set 的Object必须定义equals()方法 ,另外list支持for循环,也就是通过下标来遍历,也可以用迭代器,但是set只能用迭代,因为他无序,无法用下标来取得想要的值。)

③ Set和List对比:

Set:检索元素效率低下,删除和插入效率高,插入和删除不会引起元素位置改变。
List:和数组类似,List可以动态增长,查找元素效率高,插入删除元素效率低,因为会引起其他元素位置改变。
————————————————
 

标签:Set,list,元素,37,Collection,插入,List
From: https://www.cnblogs.com/cnetsa/p/17410415.html

相关文章

  • 41、说一下 HashSet 的实现原理?
    HashSet实际上是一个HashMap实例,数据存储结构都是数组+链表。HashSet是基于HashMap实现的,HashSet中的元素都存放在HashMap的key上面,而value都是一个统一的对象PRESENT。privatestaticfinalObjectPRESENT=newObject();HashSet中add方法调用的是底层HashMap中的put方法,put......
  • 40、set有哪些实现类?
    (1)HashSetHashSet是set接口的实现类,set下面最主要的实现类就是HashSet(也就是用的最多的),此外还有LinkedHashSet和TreeSet。HashSet是无序的、不可重复的。通过对象的hashCode和equals方法保证对象的唯一性。HashSet内部的存储结构是哈希表,是线程不安全的。(2)TreeSetTreeSet对元素......
  • Maven - settings.xml配置
      settings.xml<?xmlversion="1.0"encoding="UTF-8"?><!--LicensedtotheApacheSoftwareFoundation(ASF)underoneormorecontributorlicenseagreements.SeetheNOTICEfiledistributedwiththisworkforadditional......
  • redis中set与setnx区别
    转自:https://www.zhangshilong.cn/work/320344.htmlRedis命令SETNX的使用(包含Java分布式锁实现)可以参考Redis官网对SETNX命令的介绍:https://redis.io/commands/setnxSETNX命令简介命令格式SETNXkeyvalue将key的值设为value,当且仅当key不存在。若给定的key已经存......
  • NVRM: Xid (PCI:0000:b1:00): 13, pid=1375637, Graphics SM Global Exception on (GP
    显卡服务器中一个显卡崩溃了:May1605:38:58dellkernel:[14244871.006970]NVRM:Xid(PCI:0000:b1:00):13,pid=1375637,GraphicsSMWarpExceptionon(GPC0,TPC0,SM0):IllegalInstructionEncodingMay1605:38:58dellkernel:[14244871.010256]NVRM:Xid(PC......
  • HashSet 的基本使用
    ​ HashSet是Java中的集合类之一,它实现了Set接口,并基于哈希表实现。它不允许集合中存在重复元素,因此可以用来存储一组唯一的对象。在HashSet中,每个元素都对应着一个唯一的键值,这个键值是通过元素的hashCode()方法计算出来的。具体来说,HashSet通过将元素的hashCode()......
  • HashSet 的基本使用
    ​ HashSet是Java中的集合类之一,它实现了Set接口,并基于哈希表实现。它不允许集合中存在重复元素,因此可以用来存储一组唯一的对象。在HashSet中,每个元素都对应着一个唯一的键值,这个键值是通过元素的hashCode()方法计算出来的。具体来说,HashSet通过将元素的hashCode()......
  • Nacos 启动出现No DataSource set
     出现此问题需检查下:配置信息是否已启用,默认nacos使用内置数据库,如果要使用外置数据库时需要更改配置文件: application.properties 更新如下4个信息,设置为要使用的外部数据库信息 启动nacos如果还是出现连接数据库失败提示:在保障外部数据库可用,且配置数据连接信息......
  • docker 开启2375端口,提供外部访问docker
      一、编辑docker文件:/usr/lib/systemd/system/docker.service命令:vim/usr/lib/systemd/system/docker.service修改ExecStart行,增加内容-Htcp://0.0.0.0:2375,修改后如下:ExecStart=/usr/bin/dockerd-Htcp://0.0.0.0:2375-Hfd://--containerd=/run/containerd/con......
  • 直播商城源码,Android实现监听Settings值变化的功能
    直播商城源码,Android实现监听Settings值变化的功能先创建一个内部类继承自ContentObserver   classSettingsContentObserverextendsContentObserver{    publicSettingsContentObserver(){      super(newHandler());    }    ......