List、Map、Set的理解(LinkedList和ArrayList、Vector和ArrayList、HashMap和HashTable和HashSet区别与使用)
来源:互联网 发布:外汇交易软件下载 编辑:程序博客网 时间:2024/05/16 18:10
List特点:元素有放入顺序,元素可重复
Map特点:元素按键值对存储,无放入顺序
Set特点:元素无放入顺序,元素不可重复(注意:元素虽然无放入顺序,但是元素在set中的位置是有该元素的HashCode决定的,其位置其实是固定的)
List接口有三个实现类:LinkedList,ArrayList,Vector
LinkedList:底层基于链表实现,链表内存是散乱的,每一个元素存储本身内存地址的同时还存储下一个元素的地址。链表增删快,查找慢
ArrayList和Vector的区别:ArrayList是非线程安全的,效率高;Vector是基于线程安全的,效率低
Set接口有两个实现类:HashSet(底层由HashMap实现),LinkedHashSet
SortedSet接口有一个实现类:TreeSet(底层由平衡二叉树实现)
Query接口有一个实现类:LinkList
Map接口有三个实现类:HashMap,HashTable,LinkeHashMap
HashMap非线程安全,高效,支持null;HashTable线程安全,低效,不支持null
SortedMap有一个实现类:TreeMap
其实最主要的是,list是用来处理序列的,而set是用来处理集的。Map是知道的,存储的是键值对
set 一般无序不重复.map kv 结构 list 有序
HashSet,存储object的集合,既然是集合,就不允许有重复元素。判断两个元素是否相同,是由hashCode与equals方法共同完成的。
list、set、map以及array的区别
对于刚刚学习集合框架来说,如何选择list、set、map以及array是比较模糊的
在此我将对这四种情况做总结:
- array:数组,可以存储对象和基本数据类型,长度固定。
- Collection:集合(单列),用于存储对象、不能存储基本数据类型(int,char等),但可以存储基本数据类型包装类(int-Integer,char-Character等),长度可变
- 那么,为什么会出现这么多集合呢,我们可以把集合比如成容器。每个不同容器中对数据的存储方式不同,这种存储方式称为数据结构
- ArrayList:数组。特点:有索引(脚标),所以查找快,增删后每个元素的索引都发生改变,所以增删慢,而且数组越长增删越慢
- LinkedList:链表。特点:无索引,每个元素都包含下一元素地址,查找需要逐一进行,所以查找慢,但是增删快只需要改变元素后面的地址。
- Vector:线程同步数组 基本抛弃使用。
- :元素有序,可重复。
- :元素无序,不重复,无索引。
- HashSet:哈希表。特点:线程非同步,保证元素唯一性原理:判断hashCode是个屁相同,洗过相同在判断equals方法是否为true。
- TreeSet:二叉树。特点:可对用两种方法对集合中元素排序,1.实现comparable接口,覆盖compareTo方法。2.集合建立时规定,并自定义比较类。
- Map:双列集合,用于存放键值对。键值是唯一的,不可重复
- List、Map、Set的理解(LinkedList和ArrayList、Vector和ArrayList、HashMap和HashTable和HashSet区别与使用)
- List、Map、Set的理解(LinkedList和ArrayList、Vector和ArrayList、HashMap和HashTable和HashSet区别与使用)
- Vector与ArrayList、Hashtable和HashMap、ArrayList和LinkedList区别
- Vector和ArrayList,LinkedList,Hashtable,HashMap的区别
- Vector和ArrayList,LinkedList,Hashtable,HashMap的区别
- Vector和ArrayList,LinkedList,Hashtable,HashMap的区别
- 【Java 集合】List(ArrayList、Vector、LinkedList)、Map(HashMap、HashTable、LinkedHashMap和TreeMap)
- Vector和ArrayList,Hashtable和HashMap,ArrayList和LinkedList的区别
- Java知识点Vector和ArrayList,Hashtable和HashMap,ArrayList和LinkedList的区别
- Arraylist和linkedlist的区别,hashmap和hashtable的区别,hashmap和hashset的相同与不同,hashcode的用法
- Vector和ArrayList Hashtable和HashMap ArrayList和LinkedList
- HashMap与Hashtable的区别 ArrayList和LinkedList区别
- List和ArrayList和Vector和HashTable和HashMap区别
- List,Map,Set以及常用的ArrayList,LinkedList,HashMap的区别和用法
- ArrayList和LinkedList HashMap和Hashtable的区别的区别
- Set,List,Map,Vector,ArrayList的区别和用法
- 各种集合小结:arrayList和linkedList,Vector;hashmap和hashtable,hashset,
- ArrayList和LinkedList 以及 Hashtable和HashMap的区别
- cartographer--ros配置
- leetcode---sqrtx---分治
- WEB网站常见的攻击方式总结与原理分析
- PHP逐行读取txt文件
- Longest increasing substring2 --DP
- List、Map、Set的理解(LinkedList和ArrayList、Vector和ArrayList、HashMap和HashTable和HashSet区别与使用)
- javaScript深入学习[2]
- 安装 PowerDesigner 16 及 汉化
- Spring五个事务隔离级别和七个事务传播行为
- 端口占用问题解决办法(以1099端口为例)
- springjdbc
- hdu 5934 Bomb
- 删除文件
- JUnit4 wiki翻译