参考文档

我参考了Java 集合系列11之 Hashtable详细介绍(源码解析)和使用示例,阅读了jdk 1.8的源码

Hashtable的继承关系

Hashtable继承了Dictionary类,实现了Map、Cloneable、Serializable接口

public class Hashtable<K,V>
extends Dictionary<K,V>
implements Map<K,V>, Cloneable, java.io.Serializable

Hashtable数据结构

依赖的数组和链表,跟HashMap不一样的

Hashtable是线程安全的

共有方法就是线程安全的方法

Hashtable遍历方法

通过entrySet()去遍历,效率高
通过keySet()去遍历key,效率低
通过values遍历
通过Enumeration keys遍历
通过Enumeration elements遍历

使用例子

import lombok.extern.slf4j.Slf4j;

import java.io.ObjectStreamException;
import java.util.Collection;
import java.util.Enumeration;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.Map;
import java.util.Random;
import java.util.Set; @Slf4j
public class HashtableTest {
public static void main(String[] args) {
Hashtable hashtable = new Hashtable();
Random ran = new Random();
for (int i = 0; i < 5; i++) {
int tmp=ran.nextInt(1000);
hashtable.put(Integer.valueOf(i),String.valueOf(tmp));
}
//测试遍历
iteratorEntrySet(hashtable);
iteratorKeySet(hashtable);
iteratorValues(hashtable);
enumerationKeys(hashtable);
enumerationElements(hashtable);
//打印table
log.info("table :{}",hashtable);
//键值对个数
log.info("table size {}",hashtable.size());
//包含键
log.info("contans key 1 :{}",hashtable.containsKey(Integer.valueOf(1)));
//包含values //remove key
log.info("remove key :{}",hashtable.remove(Integer.valueOf(1)));
log.info("after remove ,table size {}",hashtable.size());
//clear
log.info("clear table ");
hashtable.clear();
//is empety
log.info("is empty: {}", hashtable.isEmpty());
} //entrySet()去遍历
public static void iteratorEntrySet(Hashtable hashtable) {
Set entry = hashtable.entrySet();
Iterator<Map.Entry> it = entry.iterator();
log.info("iteratorEntrySet:");
while (it.hasNext()) {
Map.Entry entry1=it.next();
log.info("key :{}, value :{}", entry1.getKey(), entry1.getValue());
//下面的逻辑是错误的,it.next()执行了两次,可能为空
//log.info("key :{}, value :{}", it.next().getKey(), it.next().getValue());
}
}
//keySet()去遍历key
public static void iteratorKeySet(Hashtable hashtable){
Set set =hashtable.keySet();
log.info("iteratorKeySet");
Iterator it =set.iterator();
while(it.hasNext()){
Object key =it.next();
log.info("key :{}, value :{}",key,hashtable.get(key)); }
}
//values遍历
public static void iteratorValues(Hashtable hashtable){
Collection values=hashtable.values();
log.info("iteratorValues");
Iterator it =values.iterator();
while(it.hasNext()){
log.info("value :{}",it.next());
} }
//Enumeration keys遍历
//内部类实现接口Enumeration,通过TYPE实现hasMoreElements() nextElement()方法
public static void enumerationKeys(Hashtable hashtable){
Enumeration keys = hashtable.keys();
log.info("enumerationKeys");
while(keys.hasMoreElements()){
Object key =keys.nextElement();
log.info("key :{}, value :{}",key,hashtable.get(key));
}
}
//Enumeration elements遍历
public static void enumerationElements(Hashtable hashtable){
Enumeration values =hashtable.elements();
log.info("enumerationElements");
while(values.hasMoreElements())
{
Object value =values.nextElement();
log.info("value : {}",value);
}
}
}

运行结果

D:\zxems\work\OpenJdk\8\bin\java.exe "-javaagent:D:\Program Files\JetBrains\IntelliJ IDEA 2019.1.1\lib\idea_rt.jar=52315:D:\Program Files\JetBrains\IntelliJ IDEA 2019.1.1\bin" -Dfile.encoding=GB2312 -classpath D:\zxems\work\OpenJdk\8\jre\lib\charsets.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\access-bridge-64.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\cldrdata.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\dnsns.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\jaccess.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\localedata.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\nashorn.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\sunec.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\sunjce_provider.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\sunmscapi.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\sunpkcs11.jar;D:\zxems\work\OpenJdk\8\jre\lib\ext\zipfs.jar;D:\zxems\work\OpenJdk\8\jre\lib\jce.jar;D:\zxems\work\OpenJdk\8\jre\lib\jsse.jar;D:\zxems\work\OpenJdk\8\jre\lib\management-agent.jar;D:\zxems\work\OpenJdk\8\jre\lib\resources.jar;D:\zxems\work\OpenJdk\8\jre\lib\rt.jar;D:\My\code\javalearn\java-learn\target\classes;D:\My\tools\maven\repo\org\slf4j\slf4j-log4j12\1.7.2\slf4j-log4j12-1.7.2.jar;D:\My\tools\maven\repo\org\slf4j\slf4j-api\1.7.2\slf4j-api-1.7.2.jar;D:\My\tools\maven\repo\log4j\log4j\1.2.17\log4j-1.2.17.jar java.javabase.map.HashtableTest
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - iteratorEntrySet:
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :4, value :771
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :3, value :567
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :2, value :933
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :1, value :421
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :0, value :304
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - iteratorKeySet
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :4, value :771
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :3, value :567
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :2, value :933
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :1, value :421
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :0, value :304
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - iteratorValues
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - value :771
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - value :567
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - value :933
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - value :421
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - value :304
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - enumerationKeys
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :4, value :771
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :3, value :567
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :2, value :933
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :1, value :421
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - key :0, value :304
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - enumerationElements
2019-07-15 16:57:21,254 [main] INFO java.javabase.map.HashtableTest - value : 771
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - value : 567
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - value : 933
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - value : 421
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - value : 304
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - table :{4=771, 3=567, 2=933, 1=421, 0=304}
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - table size 5
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - contans key 1 :true
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - remove key :421
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - after remove ,table size 4
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - clear table
2019-07-15 16:57:21,269 [main] INFO java.javabase.map.HashtableTest - is empty: true Process finished with exit code 0

Java Hashtable遍历与方法使用的更多相关文章

  1. java集合类遍历删除方法测试以及使用场景记录

    package test0; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java. ...

  2. java List遍历的方法

    List可以用序号来遍历,但通常推荐使用iterator来遍历Iterator itr = list.iterator();while (itr.hasNext()) { Object nextObj ...

  3. java 数组遍历(方法内部的代码)

    //数组遍历(依次输出数组中的每一个元素)二维数组: int[][] arr={{1,2},{3,4,5},{6,7}}; for(int i=0;i<arr.length;i++){ for( ...

  4. Java中遍历Map集合的四种方法

    在Java中如何遍历Map对象 How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有map都 ...

  5. java中遍历map对象的多种方法

    在Java中如何遍历Map对象   How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有ma ...

  6. Java中遍历map的四种方法 - 转载

    在Java中如何遍历Map对象 How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有map都 ...

  7. java 遍历map 方法 集合 五种的方法

    package com.jackey.topic; import java.util.ArrayList;import java.util.HashMap;import java.util.Itera ...

  8. Java中遍历Map的几种方法

      转自: http://blog.csdn.net/wzb56/article/details/7864911 方法分为两类: 一类是基于map的Entry:map.entrySet(); 一类是基 ...

  9. java中遍历MAP,嵌套map的几种方法

    java中遍历MAP的几种方法 Map<String,String> map=new HashMap<String,String>();    map.put("us ...

随机推荐

  1. How to Start Learning Computer Graphics

    Background Input\Output Image Knowledge Image Digital Image Processing Computer Vision Knowledge Com ...

  2. 「NOI2016」区间

    传送门 Luogu 解题思路 对于选出的区间,我们可以直接用线段树维护区间内单点被覆盖次数最大值. 那么解题重心便落在了选取方式上. 为了让最大值最小,考虑尺取,不能二分,降低效率而且不好写. 先将区 ...

  3. C - Water The Garden

    It is winter now, and Max decided it's about time he watered the garden. The garden can be represent ...

  4. git清除用户信息

    remote: Repository not found. fatal: repository 'https://github.com/chenbowen950908/zhongzanjiaoyu.g ...

  5. python安装MySQLclient

    直接使用pip命令安装mysqlclient : pip3 install mysqlclient 如果windows安装不了MySQL-python mysqlclient 参考以下解决方案: 这个 ...

  6. 吴裕雄--天生自然Python Matplotlib库学习笔记:matplotlib绘图(2)

    import numpy as np import matplotlib.pyplot as plt fig = plt.figure() fig.subplots_adjust(bottom=0.0 ...

  7. 基于Facebook开源框架SocketRocket的即时通讯

    SocketRocket 介绍: SocketRock 是 Facebook 开源的框架,基于 WebSocket 客户端类库,适用于 iOS.Mac OS.tv OS.GitHub 传送门:http ...

  8. [运维] 请求 nginx 出现 502 Bad Gateway 的解决方案!

    环境: 云服务器镜像 Linux CentOS 7.6 已经安装并成功配置 SSL 的 nginx 1.16.1 成功安装并且可以正常运行的 apache-tomcat-9.0.26 遇到的问题: 在 ...

  9. LeetCode.62——不同路径

    问题描述: 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为"Start" ). 机器人每次只能向下或者向右移动一步.机器人试图达到网格的右下角(在下图中标记为 ...

  10. Cake ZOJ - 3537

    题目链接 本题也是区间dp三角剖分板子题,只不过加入了判断是否是凸包,计算顺序要用凸包顺序(凸包板) #include<bits/stdc++.h> using namespace std ...