java集合比较_Java集合对比

1.array和ArrayList 的区别?

1.1:ArrayList是Array的复杂版本

1.2:数组不能扩容集合可以扩容

1.3:存储的数据类型:Array只能存储相同数据类型的数据,而ArrayList可以存储不同数据类型的数据

2.ArrayList与LinkList的区别?

相同点:

2.1:都可以重复添加元素

2.2:都是有顺序的集合

不同点:

2.3:ArrayList查询快,增删改查慢

2.4:LinkList查询慢,增删改查快(一般可以用在session版本的购物车)

3.Collection接口的remove()方法和Iterator(迭代器)接口的remove()方法区别?

性能方面:

3.1:iterator的remove方法效率高

容错方面:

3.2:iterator的遍历时不会报错

3.3:Collection接口的remove()方法有参数,Iterator(迭代器)接口的remove()方法无参数,但要在next()方法下

4.怎样将一个数组转成List,有什么方法

arrays.asList();//数组转集合方法

list.toArray();//集合转数组方法

5.HashSet、TreeSet、LinkedHashSet区别

5.1:需要速度快的集合,使用HashSet

5.2:需要集合有排序功能,使用TreeSet

5.3:需要按照插入的顺序存储集合,使用LinkedHashSet

6.HashMap、TreeMap、linkedHashMap区别?

6.1:在Map中插入、删除和定位元素,HashMap是最好的选择

6.2:需要集合有排序功能,使用TreeMap更好

6.3:需要按照插入的顺序存储集合,使用LinkedHashMap

7.HashMap和HashSet区别

HashMap:

实现了Map接口

存储键值对

调用put()向map中添加元素

HashMap使用key计算hashcode

HashMap相对于HashSet较快,因为它是使用唯一的键获取对象

HashSet:

实现了Set接口

存储对象

调用add()向set中添加元素

HashSet使用成员对象计算hashcode

HashSet较HashMap来说比较慢

8.HashMap的实现原理

通过put和get存储和获取对象,存储对象时,我们将K/V传给put方法时,它调用hashcode计算hash从而得到bucket位置,进一步存储,HashMap会根据当前bucket的占用情况自动调整容量。获取对象时,我们将K传递给get,他调用hashcode计算hash从而得到bucket位置,并进一步调用equals()方法确认键值对。

9.List、Set、Map之间的区别

9.1:list与set都继承与conllection接口

9.2:list有顺序,可以插入重复的元素

9.2:set无顺序,不可以插入重复元素

9.3:map键值存储,键唯一,值可以重复

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值