Java集合面试题

集合与数组的比较

数组不是面向对象的,存在明显的缺陷,集合弥补了数组的一 些缺点,比数组更灵活更实用,可大大提高软件的开发效率, 而且不同的集合框架类可适用不同场合。具体如下:

1:数组能存放基本数据类型和对象,而集合类中只能存放对象。

2:数组容易固定无法动态改变,集合类容量动态改变。

3:数组无法判断其中实际存有多少元素,length只告诉了数组的容量,而集合的size()可以确切知道元素的个数

4:集合有多种实现方式和不同适用场合,不像数组仅采用顺序 表方式

5:集合以类的形式存在,具有封装、继承、多态等类的特性, 通过简单的方法和属性即可实现各种复杂操作,大大提高了软件的开发效率

Collection和Collections的区别

Collection是Java提供的集合接口,存储一组不唯 一,无序的对象。它有两个子接口List和Set。

Java还有一个Collections类,专门用来操作集合类,它提供了一系列的静态方法实现对各种集合的搜索、排序、线程安全化等操作。

Collections提供的静态方法:
	addAll():批量添加
	sort():排序
	binarySearch():二分查找
	fill():替换
	shuffle():随机排序
	reverse():逆序

ArrayList和LinkedList的联系和区别

ArrayList实现了长度可变的数组,在内存中分配连续空间。遍历元素和随机访问元素效率比较高。

LinkedList采用链表存储方式。插入、删除元素效率比较高。

Vector和ArrayList的联系和区别

实现原理相同,功能相同,都是长度可变的数组结构,很多时候可以互用,两者的主要区别如下:

  • Vector是早期的JDK接口,ArrayList是替代Vector的新接口
  • Vector线程安全,ArrayList重速度轻安全,线程非安全
  • 长度需要增长时,Vector默认增长一倍,ArrayList增长50% (1.5+1)

HashMap和Hashtable的联系和区别

实现原理相同,功能相同,底层都是哈希表结构,查询速度快,在很多情况下可以互用,两者的主要区别如下:

  • Hashtable是早期的JDK提供的接口,HashMap是新版的JDK提供的接口
  • Hashtable继承Dictionary类,HashMap实现Map接口
  • Hashtable是线程安全,HashMap线程非安全
  • Hashtable丌允许null值,HashMap允许null值
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值