HashMap:

    java.lang.Object

      java.util.AbstractMap<K,V>
       ∟ java.util.HashMap<K,V>

  类型参数:

  K - 此映射所维护的键的类型
  V - 所映射值的类型
  public class HashMap<K,V> extends AbstractMap<K,V> implements Map<K,V>, Cloneable, Serializable

  HashMap是基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。

HashTable:

    java.lang.Object
       ∟java.util.Dictionary<K,V>
           ∟java.util.Hashtable<K,V>

  类型参数:

  K - 此映射所维护的键的类型
  V - 所映射值的类型
       public class Hashtable<K,V>extends Dictionary<K,V>implements Map<K,V>, Cloneable, Serializable

  HashTable将键映射到相应的值。任何非 null 对象都可以用作键或值。

HashMap与HashTable:

  HashTable 继承了Dictionary,是线程安全的,键值对中不能出现 null.

HashMap 实现了 Map接口,是HashTable的轻量级实现(非线程安全的实现),即多个线程访问HashMap时需要为其准备外同步,且Hashmap的键、值可以为空。

遍历Map有两种方式:keySet(效率低)、entrySet(效率高),两种方式都需要创建Iterator迭代器对象,但创建方式有所不同。

keySet():返回值是Map中的key值的集合

entrySet():返回值是set集合, 集合类型为Map.Entry

Demo:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry; public class Test1 {
public static void main(String[] args){
ArrayList<Double> arr1 = new ArrayList<Double>();
arr1.add(1.23);
arr1.add(2.21);
arr1.add(4.59); // 迭代器方式遍历list
Iterator<Double> iterator = arr1.iterator();
while(iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println(); 
System.out.println("----------分界线---------");
Double arr2[] = arr1.toArray(new Double[0]); // list转数组方式遍历list
for(int i=0;i<arr2.length;i++){
System.out.print(arr2[i]+" ");
}
System.out.println();
System.out.println("----------分界线---------");
HashSet<Double> set1 = new HashSet<Double>();
set1.add(2.25);
set1.add(3.78);
set1.add(9.54); // 迭代器方式遍历set
Iterator<Double> iterator1 = set1.iterator();
while(iterator1.hasNext()){
System.out.print(iterator1.next()+" ");
}
System.out.println();
System.out.println("----------分界线---------"); // set转数组方式遍历set
Double arr3[] = set1.toArray(new Double[0]);
for(int i=0;i<arr3.length;i++){
System.out.print(arr3[i]+" ");
}
System.out.println();
System.out.println("----------分界线---------");
HashMap<Character,Integer> map1 = new HashMap<Character,Integer>();
HashMap<String,Integer> map2 = new HashMap<String,Integer>();
map1.put('d', 5);
map1.put('t', 9);
map1.put('p',13);
map2.put(Character.toString('a'), 1);
map2.put("aa", 2);
map2.put("aaa", 3); // 迭代器中的entrySet方式遍历HashMap
Iterator<Entry<Character,Integer>> iterator3 = map1.entrySet().iterator();
while(iterator3.hasNext()){
Map.Entry<Character, Integer> entry = iterator3.next();
System.out.print(entry.getKey()+":"+entry.getValue()+" ");
}
System.out.println();
System.out.println("----------分界线---------"); // 迭代器中的KeySet方式遍历HashMap
Iterator<String> iterator4 = map2.keySet().iterator();
while(iterator4.hasNext()){
String s = iterator4.next();
System.out.print(s+":"+map2.get(s)+" ");
}
System.out.println();
System.out.println("----------分界线---------");
System.out.println(map2.containsKey("aa"));
System.out.println(map2.containsValue(2));
}
}

运行结果:

1.23 2.21 4.59
----------分界线---------
1.23 2.21 4.59
----------分界线---------
2.25 3.78 9.54
----------分界线---------
2.25 3.78 9.54
----------分界线---------
p:13  d:5  t:9 
----------分界线---------
aa:2  aaa:3  a:1 
----------分界线---------
true
true

浅谈Java中的Hashmap的更多相关文章

  1. 【转】浅谈Java中的hashcode方法(这个demo可以多看看)

    浅谈Java中的hashcode方法 哈希表这个数据结构想必大多数人都不陌生,而且在很多地方都会利用到hash表来提高查找效率.在Java的Object类中有一个方法: public native i ...

  2. 【转】浅谈Java中的hashcode方法

    哈希表这个数据结构想必大多数人都不陌生,而且在很多地方都会利用到hash表来提高查找效率.在Java的Object类中有一个方法: public native int hashCode(); 根据这个 ...

  3. 浅谈Java中的hashcode方法(转)

    原文链接:http://www.cnblogs.com/dolphin0520/p/3681042.html 浅谈Java中的hashcode方法 哈希表这个数据结构想必大多数人都不陌生,而且在很多地 ...

  4. 浅谈Java中set.map.List的区别

    就学习经验,浅谈Java中的Set,List,Map的区别,对JAVA的集合的理解是想对于数组: 数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),JAVA集合可以存储和操 ...

  5. Java基础学习总结(29)——浅谈Java中的Set、List、Map的区别

    就学习经验,浅谈Java中的Set,List,Map的区别,对JAVA的集合的理解是想对于数组: 数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),JAVA集合可以存储和操 ...

  6. 浅谈Java中的equals和==(转)

    浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: 1 String str1 = new String("hello"); 2 String str ...

  7. 浅谈Java中的对象和引用

    浅谈Java中的对象和对象引用 在Java中,有一组名词经常一起出现,它们就是“对象和对象引用”,很多朋友在初学Java的时候可能经常会混淆这2个概念,觉得它们是一回事,事实上则不然.今天我们就来一起 ...

  8. 浅谈Java中的equals和==

    浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: String str1 = new String("hello"); String str2 = ...

  9. 浅谈Java中的深拷贝和浅拷贝(转载)

    浅谈Java中的深拷贝和浅拷贝(转载) 原文链接: http://blog.csdn.net/tounaobun/article/details/8491392 假如说你想复制一个简单变量.很简单: ...

随机推荐

  1. Phpstorm如何连接服务器

    当服务器是Linux的时候不懂指令觉得很懊恼,这个时候直接就可以使用PHPstorm连接服务器操作了: 1丶准备工作 首先你先要准备服务器丶phpstorm这两个吧! 2丶开始配置phpstorm 按 ...

  2. python3爬虫-使用requests爬取起点小说

    import requests from lxml import etree from urllib import parse import os, time def get_page_html(ur ...

  3. ruby puts, print, p方法比较

    1.puts([obj[, obj2[, ....]]] ) 依次将obj和换行符输出到$>.若没有参数的话则只会输出换行符. 若参数是数组,则依次输出数组元素和换行符.若将既非数组又非字符串的 ...

  4. Golint的简易使用方法

    根据作者的说法: Golint is a linter for Go source code. Golint differs from gofmt. Gofmt reformats Go source ...

  5. 在vivado中自定义编辑器

    在 Tools - Options - Text Editor 中选择 Custom Editor 这里我用的gvim,在Editor文本框中输入: C:/Vim/vim80/gvim.exe --r ...

  6. msfconsole 无法启动,解决办法

    今天突然碰上kali msfconsole 无法启动,经过查找资料,现已成功解决该问题,现将解决办法整理如下: service postgresql start # 启动数据库服务 msfdb ini ...

  7. c++ 双向循环链表

    教学内容: 循环双链表 建立循环双链表 循环链表里插入结点 遍历循环链表 双向链表结构定义 struct stu_data { ];//学生名字 struct mytime stuTime;/ ...

  8. 软考计算机网络原理之IP计算问题汇总

    转自 http://www.cnblogs.com/jyh317/archive/2013/04/14/3018650.html 1.IP地址 分类: ①A类IP地址 ②B类IP地址 ③C类IP地址 ...

  9. 3、计数排序,电影top100

    1.计数排序 # -*- coding: utf-8 -*- # @Time : 2018/07/31 0031 11:32 # @Author : Venicid def count_sort(li ...

  10. 【oracle查询】oracle查询字段显示#号 (井号)

    客户反映字段查询为井号,我自己没有遇到这种情况,于是上网百度了一下. 下面的答案很好地解决了问题,哈哈哈.