博客
关于我
Map linkedMap,HashTable
阅读量:659 次
发布时间:2019-03-15

本文共 1049 字,大约阅读时间需要 3 分钟。

LinkedMap

哈希表和链表实现的Map接口,具有可预测的迭代次序。 这种实现不同于HashMap,它维持于所有条目的运行双向链表。 此链接列表定义迭代排序,通常是将键插入到地图(插入顺序 )中的顺序 。 请注意,如果将键重新插入到地图中,则插入顺序不受影响。 (A键k被重新插入到地图m如果当m.containsKey(k)将返回true之前立即调用m.put(k, v)被调用。)

底层原理
哈希表+链表(记录元素的顺序)
代码:

public class Demo05LinkedHashMap {public static void main(String[] args) {    HashMap
map=new HashMap<>(); map.put("a","a"); map.put("c","c"); map.put("b","b"); map.put("a","d"); System.out.println(map);//{a=d, b=b, c=c}key值不允许重复,无序 System.out.println("--------------------------------------------------------"); LinkedHashMap
map1=new LinkedHashMap<>(); map1.put("a","a"); map1.put("c","c"); map1.put("b","b"); map1.put("a","d"); System.out.println(map1);//{a=d, c=c, b=b}key值不允许重复,有序}}

显示效果:

{a=d, b=b, c=c}

-------------------------------------------
{a=d, c=c, b=b}

hashtable

hashtable<K,v>集合implements Map<k,v>接口

  • 是一个线程安全的集合,单线程,底层是一个哈希表,速度慢
  • hashtable不可以存储null值,
  • 在1.2之后hashtable和vector被更先进的hashmap,arraylist取代了
  • hashtable的子类properties依然活跃
  • properties集合是唯一一个和IO流相结合集合

转载地址:http://xljmz.baihongyu.com/

你可能感兴趣的文章
NervanaGPU 项目使用教程
查看>>
Nerves 项目教程
查看>>
nessus快速安装使用指南(非常详细)零基础入门到精通,收藏这一篇就够了
查看>>
Nessus漏洞扫描教程之配置Nessus
查看>>
Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
查看>>
nested exception is org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML.
查看>>
nestesd exception is java .lang.NoSuchMethodError:com.goolge.common.collect
查看>>
nestJS学习
查看>>
net core 环境部署的坑
查看>>
NET Framework安装失败的麻烦
查看>>
Net 应用程序如何在32位操作系统下申请超过2G的内存
查看>>
Net.Framework概述
查看>>
NET3.0+中使软件发出声音[整理篇]<转>
查看>>
net::err_aborted 错误码 404
查看>>
NetApp凭借领先的混合云数据与服务把握数字化转型机遇
查看>>
NetAssist网络调试工具使用指南 (附NetAssist工具包)
查看>>
Netbeans 8.1启动参数配置
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
NetBeans之JSP开发环境的搭建...
查看>>
NetBeans之改变难看的JSP脚本标签的背景色...
查看>>