集合框架中几种集合的关系和区别

一.ArrayList和HashSet区别

ArrayList 有序   List中的数据可以重复。

HashSet  无序  Set中的数据不能够重复。

重复判断的标准:

注意:看的是HashCode是否相同:

如果Hashcode不同,则是不同的数据。

Hashcode 相同的话,再比较equals,如果equals相同,则是相同的数据,否则不是。

二.ArrayList和LinkedList的区别

ArrayList   数组形式保存对象   插入,删除数据慢,查询较快。

LinkedList  将对象保存在一个独立的空间。 查询较慢, 插入,删除数据快。

ArrayList是顺序结构,所以定位快,指哪里找哪里。

LinkedList 是链表结构,就像手里的一串珠子一样,要找到第88颗珠子,就必须一个个数过去,所以定位很慢。

三.HashMap和Hashtable的区别

HashMap和Hashtable都实现了Map集合接口都是键值对保存数据的方式。

区别1:

HashMap类没有分类或者排序。允许一个Null键和多个Null值。

Hashtable类似HashMap,但不允许一个Null键和多个Null值,比HashMap慢,因为他是同步的。

区别2:

HashMap不是线程安全的类。

Hashtable是线程安全的类。

四.HashSet LinkedHashSet 和 TreeSet的区别‘

 HashSet特点:

  无序,不是同步的,集合可以是Null,但是只能有一个Null。

LinkedHashSet特点:

按照插入顺序。

TreeSet特点:

自动排序。





猜你喜欢

转载自blog.csdn.net/qq_39507327/article/details/80950875