2016 - 2024

感恩一路有你

arraylist底层数据结构是 JAVA中几种集合(List、Set和Map)的区别?

浏览量:2248 时间:2021-04-14 07:47:45 作者:admin

JAVA中几种集合(List、Set和Map)的区别?

java.util文件

在包中,set、list和map是接口。集合中的对象没有按特定方式排序,并且没有重复的对象。但是它的一些实现类可以用特定的方式对集合中的对象进行排序,比如TreeSet类,它可以在默认情况下或通过实现进行排序java.util.Comparator比较程序

接口定义排序方法。列表中的对象根据索引位置排序,可以有重复的对象,并且可以根据集合中对象的索引位置检索对象,例如列表.获取(i) 方法获取列表集合中的元素。映射中的每个元素都包含一个键对象和一个值对象,它们成对出现。键对象不能复制,值对象可以复制。map的功能和方法:method put(object key,object value)添加一个“value”(你想要什么)和一个与“value”关联的“key”(用它来查找)。方法get(objectkey)返回与给定键关联的值。您可以使用containskey()和containsvalue()来测试映射是否包含“键”或“值”。标准Java类库包含几个不同的映射:HashMap、treemap、LinkedHashMap、weakhashmap、identityhashmap。它们具有相同的基本接口图,但在行为、效率、排序策略、保存对象的生命周期、确定“键”等价性的策略等方面有所不同。执行效率是map的一个大问题。如果您看看get()的作用,就会明白为什么在ArrayList中搜索“keys”相当慢。这就是HashMap加速的地方。HashMap使用一个称为哈希码的特殊值,而不是缓慢地搜索键。哈希代码是一个相对唯一的int值,用于表示对象。它是通过转换对象的某些信息而生成的。所有Java对象都可以生成哈希代码,因为hashcode()是在基类对象中定义的方法。

根据集合中元素的多少,集合可以分为哪三类?

空集,有限集,无限集。有限集合是指集合中元素的个数是有限的,如集合a=(1,2,3,4,5)。无限集合意味着集合中元素的数目是无限的。例如,设置B=(1,2,3,4,5,6。N) 表示正整数集。这个数字是无限的。空集是一个没有元素的集合。但请注意,C=(0)不是一个空集,因为0是一个元素。例如,集合D=(x,x的绝对值小于0)是一个空集,因为没有这样的x。

java中什么叫集合?

Java集合包括:list,set,map,tool class collections

list包括以下子类

1。ArrayList

内部动态数组的实现,添加时有序,按索引遍历时有序,线程不安全类。

2. LinkedList

是从abstractsequential列表继承的双向链表。它可以作为堆栈、队列或双终端队列进行操作。可以实现列表接口。实现了Deque接口,该接口可以作为一个双终端队列使用。实现了Cloneable接口,包括clone(),它可以被克隆。实现java.io.Serializable可序列化接口,这意味着LinkedList支持序列化,并且可以通过序列化进行传输。插入顺序可以保持

3。ArrayList和LinkedList

的区别是数组队列,它等价于动态数组。采用阵列实现,随机存取效率高,随机插入和随机删除效率低。这是一个双向链表。它也可以作为堆栈、队列或双终端队列进行操作。LinkedList的随机访问效率较低,但随机插入和删除效率较低。

4. copyonwritearaylist

线程安全列表,写入时复制,写入时锁定,复制容器,读取时不锁定。

5. Vector

线程安全类,数组实现。读锁,写锁,低性能。

arraylist底层数据结构是 常见的集合类有哪些 集合有哪几种类型

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。