好问题
Good  Question
  • 首 页
  • 问题
    • PHP
    • JAVA
    • CPlusPlus
    • C#
    • SQL
  • 关 于
  • 联 系
HashMap,LinkedHashMap和TreeMap之间的区别 关闭 返回上一级  

HashMap,LinkedHashMap和TreeMap之间的区别
+ 查看更多

发布日期:2018-03-10 11:48
分类:JAVA
浏览次数:51
Java中的HashMap,LinkedHashMap和TreeMap有什么区别? 我没有看到输出的任何差异,因为所有三个都有keySet和values。 什么是Hashtables?
Map m1 = new HashMap();
m1.put("map", "HashMap");
m1.put("schildt", "java2");
m1.put("mathew", "Hyden");
m1.put("schildt", "java2s");
print(m1.keySet());
print(m1.values());

SortedMap sm = new TreeMap();
sm.put("map", "TreeMap");
sm.put("schildt", "java2");
sm.put("mathew", "Hyden");
sm.put("schildt", "java2s");
print(sm.keySet());
print(sm.values());

LinkedHashMap lm = new LinkedHashMap();
lm.put("map", "LinkedHashMap");
lm.put("schildt", "java2");
lm.put("mathew", "Hyden");
lm.put("schildt", "java2s");
print(lm.keySet());
print(lm.values());

回答

这三个类都实现了Map接口,并提供大多相同的功能。最重要的区别是迭代的顺序:
HashMap完全不保证迭代顺序。当添加新元素时,它可以甚至会完全改变。 TreeMap将根据关键字的“自然排序”根据他们的compareTo()方法(或外部提供的比较器)进行迭代。此外,它实现SortedMap接口,其中包含依赖于此排序顺序的方法。 LinkedHashMap将按照条目放入映射的顺序进行迭代。
“Hashtable”是基于散列的映射的通用名称。在Java API的上下文中,Hashtable是Java 1.1之前的集合框架存在之前的过时类。它不应该再使用了,因为它的API混杂着过时的方法,重复的功能,它的方法是同步的(这可能会降低性能,一般是无用的)。最好使用ConcurrrentHashMap而不是Hashtable。
上一篇在Java中获取当前工作目录
无法启动Eclipse - Java was started but returned exit code=13下一篇
下一篇无法启动Eclipse - Java was started but returned exit code=13

最新文章

  • 函数`__construct`用来干嘛的
    发布日期:2018-03-26
  • 通过访客的IP得到他们的地区
    发布日期:2018-03-26
  • 合并两个PHP对象的最好的方法是什么?
    发布日期:2018-03-26
  • 该如何把一该如何把一个对象转化成数组?
    发布日期:2018-03-26
  • 什么是输出缓冲区?
    发布日期:2018-03-26
  • 在PHP中怎么把用逗号分隔的字符串分隔在一个数组里?
    发布日期:2018-03-26
  • 在PHP中使用foreach循环时查找数组的最后一个元素
    发布日期:2018-03-26
关于好问
收集整理一些有用的问题和回答,造福中国的程序旺和IT喵们!
友情链接
起飞页 
相关信息
版权声明
Copyright © 2016 - 2017  苏州卡达网络科技有限公司 好问 GOODQ.TOP 备案号:苏ICP备09008221号-5