参考文档

我参考了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. Python使用Tensorflow出现错误: UserWarning: The default mode, 'constant'

    Python使用Tensorflow出现错误: UserWarning: The default mode, 'constant', will be changed to 'reflect' in s ...

  2. unittest如何制作测试套件Testsuite 按method,class ,module,按命令行执行unittest

    cmd 执行unittest case : python -m unitest test.py  test2.py python -m unittest  testfile.testclass.tes ...

  3. P1893山峰瞭望

    传送门 看完这个题,大家都懂意思吧,然后代码呢,emmmmm #include <bits/stdc++.h> using namespace std; const int maxn = ...

  4. 工业现场总线和工业以太网和工业IIOT

    IIoT 称为工业物联网 ,包括机器的预测性维护和生产单元的自动化控制.以更高的速度获取和访问更大量的数据,打破数据孤岛,并将所有人员,数据和流程从工厂车间连接到执行办公室.企业领导者可以使用 IIo ...

  5. 洛谷 CF804B Minimum number of steps

    嗯... 题目链接:https://www.luogu.org/problemnew/show/CF804B 这道题没有什么技巧,只是一道找规律的题. 首先看到“ab”可以换成“bba”,所以首先要确 ...

  6. Dart语言学习(十五) Dart函数方法

    Dart函数方法可分为两类: 一.内置方法/函数: print(); 二.自定义方法: 自定义方法的基本格式: 返回类型 方法名称(参数1,参数2,...){ 方法体 return 返回值; } vo ...

  7. 多Python版本共存

    Python 3.4 和 3.7 共存 我的电脑上同时安装了 Python 3.4 和 Python 3.7 两个 Python 版本.现在打开终端窗口进入指定的版本. py -3.4 py -3.7 ...

  8. Python中神秘的-5到256

    注:本文不区分作为编程语言的Python和作为语言实现的Python.后者均默认为CPython. 了解他人对Python源代码的掌握情况,我喜欢问这样一个问题 请问,在Python中,256和257 ...

  9. 导出EXCEL设置单元格格式

    怎么设置导出的EXCEL文件的列格式 如何设置导出的EXCEL文件的列格式在office的EXCEL中我们可以在一个EXCEL文件中,选中一列再点击鼠标右键,选择设置单元格格式,可以将这一列设为文本格 ...

  10. CentOS使用日常

    安装Teamview TeamViewer官网 下载rpm包 yum install -y teamviewer.x86_64.rpm 搞定 systemctl status firewalld #查 ...