03Java常见问题之容器

1. Java 容器都有哪些?

Java 容器分为 Collection 和 Map 两大类

  • Collection
    • List
      • ArrayList
      • LinkedList
      • Vector
      • Stack
    • Set
      • HashSet
      • LinkedHashSet
      • TreeSet
  • Map
    • HashMap
      • LinkedHashMap
    • TreeMap
    • ConcurrentHashMap
    • Hashtable

2. Collection 和 Collections 有什么区别?

  1. Collection 是一个集合接口。它提供了对集合对象进行基本操作的通用接口方发,所有集合都是他的子类。
  2. Collections 是一个包装类。它包含有各种有关集合操作的静态多态方法,就像一个工具类,比如提供排序的方法:collections.sort(list)。

3. List、Set、Map有什么区别?

List、Set、Map的区别主要体现在两个方面:元素是否有序、是否允许元素重复。
三者之间的区别如下表:
在这里插入图片描述

4. ArraysList、LinkedList和Vector的区别?

1.底层实现
ArraysList是变长数组
LinkedList是双向链表
Vector是变长数组
2.增删改查
ArraysList:查询快,增删改慢,原因:底层数组操作连续的内存空间
LinkedList:增删改快,查询慢,原因:底层操作链表进行断链操作
3.效率
ArraysList、LinkedList效率高(绝大部分使用),线程非安全
Vector效率低,(极少使用),线程安全

5. Array和ArrayList有什么区别?

Array可以存储基本数据类型和对象,ArrayList只能存储对象。
Array是固定大小的,而ArrayList大小是自动扩展的。
Array内置方法没有ArrayList多。

追问:数组和容器互相转换的方法?
一、容器转化到数组使用toArray()方法
二、数组转化为容器,使用Arrays.asList(数组)会返回一个ArrayList,

6. HashMap和Hashtable有什么区别?

存储:HashsMap运行Key和value为null,而Hashtable不行。
线程安全:Hashtable是线程安全的,而HashMap是非线程安全的。
推荐使用:Hashtable是保留类不建议使用,推荐在单线程环境下使用HashMap 替代,如果使用多线程则用ConcurrentHashMap替代。

7. HashMap是怎么解决哈希冲突的?

哈希:把任意长度的输入通过散列算法,变换成固定长度的输出,该输出就是散列值(哈希值);
哈希冲突:当两个不同的输入值,根据同一散列函数计算出相同的散列值的现象,我们就把它叫做碰撞(哈希碰撞)。
使用一种叫做链地址法的方式可以解决哈希冲突

8.如何循环遍历Map?

因为Map这个类没有继承Iterable接口所以不能直接通过map.iterator来遍历
Set<Entry<String,User>> entrySet=maps.EntrySet();
Iterator<Entry<String,User>> itSet=entry.iterator();
while(itSet.hasNext()){
Entry<String,User> entry = itSet.next();
System.out/println(entry);
}
//map迭代
entry.getValue();
entry.getKey();
//取map中的值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值