java面试题
来源:互联网 发布:淘宝开店的押金怎么退 编辑:程序博客网 时间:2024/05/17 08:21
1. ArrayList,LinkedList,Set的区别是什么?
ArrayList 实现List接口 ,随着向 ArrayList 中不断添加元素,其容量也自动增长
对于处理一列数据项,Java提供了两个类ArrayList和LinkedList, ArrayList的内部实现是基于内部数组Object[], 所以从概念上讲,它更象数组,但LinkedList的内部实现是基于一组连接的记录,所以,它更象一个链表结构,所以,它们在性能上有很大的差别。
在ArrayList的前面或中间插入数据时,你必须将其后的所有数据相应的后移,这样必然要花费较多时间,所以,当你的操作是在一列 数据的后面添加数据而不是在前面或中间,并且需要随机地访问其中的元素时,使用ArrayList会提供比较好的性能
而访问链表中的某个元素时,就必须从链表的一端开始沿着连接方向一个一个元素地去查找,直到找到所需的元素为止,所以,当你的操作是在一列数据的前面或中间添加或删除数据,并且按照顺序访问其中的元素时,就应该使用LinkedList了
Set一个不包含重复元素的容器
2.Hashtable和Hashmap如何使用?有什么很大的区别?
1.Hashtable是Dictionary的子类,HashMap是Map接口的一个实现类;
2.Hashtable中的方法是同步的,而HashMap中的方法在缺省情况下是非同步的。即是说,在多线程应用程序中,不用专门的操作就安全地可以使用Hashtable了;而对于HashMap,则需要额外的同步机制。但HashMap的同步问题可通过Collections的一个静态方法得到解决:
Map Collections.synchronizedMap(Map m)
这个方法返回一个同步的Map,这个Map封装了底层的HashMap的所有方法,使得底层的HashMap即使是在多线程的环境中也是安全的。同步是有代价的,而Hashtable的同步机制是无法在不需要的时候关闭掉的,因此编程中出于性能的考虑,我们都应该首选HashMap。
3.在HashMap中,null可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为null。当get()方法返回null值时,即可以表示HashMap中没有该键,也可以表示该键所对应的值为null。因此,在HashMap中不能由get()方法来判断HashMap中是否存在某个键,而应该用containsKey()方法来判断
2.Hashtable中的方法是同步的,而HashMap中的方法在缺省情况下是非同步的。即是说,在多线程应用程序中,不用专门的操作就安全地可以使用Hashtable了;而对于HashMap,则需要额外的同步机制。但HashMap的同步问题可通过Collections的一个静态方法得到解决:
Map Collections.synchronizedMap(Map m)
这个方法返回一个同步的Map,这个Map封装了底层的HashMap的所有方法,使得底层的HashMap即使是在多线程的环境中也是安全的。同步是有代价的,而Hashtable的同步机制是无法在不需要的时候关闭掉的,因此编程中出于性能的考虑,我们都应该首选HashMap。
3.在HashMap中,null可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为null。当get()方法返回null值时,即可以表示HashMap中没有该键,也可以表示该键所对应的值为null。因此,在HashMap中不能由get()方法来判断HashMap中是否存在某个键,而应该用containsKey()方法来判断
- Java面试题-朋友的面试题
- java 阿里面试题 百度面试题 CVTE面试题
- Java面试题集
- JAVA面试题
- Java面试题集
- Java 面试题
- JAVA面试题集
- java面试题1
- JAVA华为面试题
- java常用面试题
- java面试题
- JAVA面试题集
- JAVA面试题集
- java面试题集
- [转载] JAVA面试题
- Java面试题集
- JAVA面试题-1
- [转载] JAVA面试题
- Android display架构分析六-Surface manager介绍
- C和C++中使用结构体的一点区别
- C#反编译
- Android系统原理与源码分析(1):利用Java反射技术阻止通过按钮关闭对话框
- U盘安装UbuntuServer_adm64_10.04
- java面试题
- 目标与执行[拖欠一篇]
- [转]读书笔记《c语言深度解剖》(1)
- MFC 加载 光标
- 教你建一个别人既[无法打开]也[无法删除]的文件夹
- 金额转换,阿拉伯数字转换成中国传统形式。
- 创建触发器及函数
- C# Tip -- Component 子类标准化事件实现机制
- Android的反射机制Reflection