1、 HashTable和 HashMap, Vector和 Arraylist的区别?
2、 为什么equals()方法重写后,HashCode的方法也得重写?
3、 递归都可以用循环来实现,两者的优劣?什么情况只能用循环?
4、 Java有内存泄露吗?
5、容器有什么用?它有什么好处?会带来什么问题?
2、 为什么equals()方法重写后,HashCode的方法也得重写?
3、 递归都可以用循环来实现,两者的优劣?什么情况只能用循环?
4、 Java有内存泄露吗?
5、容器有什么用?它有什么好处?会带来什么问题?
解决方案 »
- myeclipse自动提示的内容能修改吗?
- 纯Java开发的游戏引擎V0.5--DEMO2 -- 物理引擎
- swing 启动tomcat 的问题
- 谁能给一个控制台下的ant代码
- 连接数据库问题
- 怎样得到JTextArea里面某一行的数据?
- thinking in java 上的代码,顺便散分
- Graphics2D生成大图片遇到的问题!
- 在线等!! java txt导出的问题
- 如何用java -Xms 来增加缓存?
- 有个实验题目,还剩下一个取得鼠标坐标的没有写好,哪位朋友能否帮我补充一下,非常感谢
- java或者jsp里面可以根据链接的地址,保存网页吗?比如我要保存www.baidu.com/index.html我可以通过一个什么方法自动的保存呢(难点是在
HashMap 类没有分类或者排序。它允许一个 null 键和多个 null 值。
Hashtable 类似于 HashMap,但是不允许 null 键和 null 值。它也比 HashMap 慢,因为它是同步的。
Hashtable和HashMap类有三个重要的不同之处。第一个不同主要是历史原因。Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现。 也许最重要的不同是Hashtable的方法是同步的,而HashMap的方法不是。这就意味着,虽然你可以不用采取任何特殊的行为就可以在一个多线程的应用程序中用一个Hashtable,但你必须同样地为一个HashMap提供外同步。一个方便的方法就是利用Collections类的静态的synchronizedMap()方法,它创建一个线程安全的Map对象,并把它作为一个封装的对象来返回。这个对象的方法可以让你同步访问潜在的HashMap。这么做的结果就是当你不需要同步时,你不能切断Hashtable中的同步(比如在一个单线程的应用程序中),而且同步增加了很多处理费用。 第三点不同是,只有HashMap可以让你将空值作为一个表的条目的key或value。HashMap中只有一条记录可以是一个空的key,但任意数量的条目可以是空的value。这就是说,如果在表中没有发现搜索键,或者如果发现了搜索键,但它是一个空的值,那么get()将返回null。如果有必要,用containKey()方法来区别这两种情况。