免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 694 | 回复: 0
打印 上一主题 下一主题

20个最佳的Java集合框架面试题目 [复制链接]

论坛徽章:
50
15-16赛季CBA联赛之深圳
日期:2017-07-17 11:07:49皇马
日期:2016-01-27 12:43:05切尔西
日期:2016-01-27 12:43:05AC米兰
日期:2016-01-27 12:43:05洛杉矶湖人
日期:2016-01-27 12:43:05明尼苏达森林狼
日期:2016-01-27 12:43:05圣安东尼奥马刺
日期:2016-01-27 12:43:05休斯顿火箭
日期:2016-01-27 12:43:05芝加哥公牛
日期:2016-01-27 12:43:05新泽西篮网
日期:2016-01-27 12:43:0515-16赛季CBA联赛之山东
日期:2016-01-27 12:40:04曼联
日期:2016-01-27 12:43:05
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-11-12 10:00 |只看该作者 |倒序浏览
1为什么Map接口不继承Collection 接口?
· Set是无序集合,并且不允许重复的元素
· List是有序的集合,并且允许重复的元素
· 而Map是键值对
· 它被视为是键的set和值的set的组合
· Map被设计为键值对的集合,所以不需要继承Collection 接口

2HashMap和Hashtable之间的区别?
· 同步或线程安全
· Null键和Null值
· 迭代值
· 默认容量大小


3comparable 和 comparator的不同之处?
· comparable接口实际上是出自java.lang包
· 它有一个 compareTo(Object obj)方法来将objects排序
· comparator接口实际上是出自 java.util 包
· 它有一个compare(Object obj1, Object obj2)方法来将objects排序


4如何对Object的list排序?
· 对objects数组进行排序,我们可以用Arrays.sort()方法
· 如果要对objects的集合进行排序,需要使用Collections.sort()方法


5fail-fast 与 fail-safe 之间的区别?
· Fail fast快速地报告任何的failure。无论何时任何一个问题都会引发 fail fast系统fails
· 在Java Fail fast 迭代器中,迭代objects集合有时会出现并发修改异常,出现这种情况有2个原因
· 如果一个线程正在迭代一个集合,而另一个线程同时试图修改这个集合
· 在调用remove()方法后,如何我们还试图去修改集合object


6Iterator、ListIterator 和 Enumeration的区别?
· Enumeration接口在Java1.2版本开始有,所以Enumeration是合法规范的接口
· Enumeration使用elements()方法
· Iterator对所有Java集合类都有实现
· Iterator使用iterator方法
· Iterator只能往一个方向前进
· ListIterator仅仅对List类型的类实现了
· ListIterator使用listIterator()方法

7Java 中 Set 与 List 有什么不同?
· Set是一个不允许重复元素存在的集合
· Set没有索引
· Set仅仅允许一个null值
· Set有类:HashSet、LinkedHashMap、TreeSet
· List有索引
· List允许N个null值
· List可以按插入顺序显示
· List有类:Vector、ArrayList、LinkedList


8arraylist 与 vector 的区别?
· Vector 在Java的第一个版本就引入了,也就是说vector是一个合法规范的类
· ArrayList在Java1.2版本引入的,是Java 集合框架的组成部分
· Vector是同步的
· ArrayList是不同步的


9什么类实现了List接口?
· ArrayList
· LinkedList
· Vector


10什么类实现了Set接口?
· HashSet
· LinkedHashSet
· TreeSet


11如何保证一个集合线程安全?
· Vector, Hashtable, Properties 和 Stack 都是同步的类,所以它们都线程安全的,可以被使用在多线程环境中
· 使用Collections.synchronizedList(list)) 方法,可以保证list类是线程安全的
· 使用java.util.Collections.synchronizedSet()方法可以保证set类是线程安全的


12是否可以往 TreeSet 或者 HashSet 中添加 null 元素?
· 可以往 hashset 中添加一个 null
· TreeSet 也允许一个 null值


13解释下Collection的接口继承关系?





14Iterator符合哪个设计模式?
· Iterator 设计模式


15HashSet 实现了哪个数据结构?
· HashSet 内部实现了hashmap


16为什么 Collection 不能继承 Cloneable 和 Serializable?
· List和Set唯一继承 Collection 接口
· SortedMap 继承了 Map 接口


17hashCode() 和 equals() 方法的重要性?如何在Java中使用它们?
· hashCode() 和 equals() 方法定义在"object"类中
· 如果equals() 方法在比较2个对象时返回true,那么hashCode()的返回值必须得一样


18array 和 arraylist 的区别?
· Array类似object集合类型,大小固定
· Arraylist是同质和异质元素的集合


19什么是 Properties 类?
· Properties 是Hashtable的子类。它被用于维护值的list,其中它们的键、值都是String类型


20如何将一个字符串转换为arraylist?
· 使用 arrayList.toArray() 方法

来源:小象科技
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP