主要的方法

+ 构造方法:
* HashMap();
- 默认大小16,负载因子0.75
* HashMap(int initialCapacity);
* HashMap(int initialCapacity,float loadFactor);
* HashMap(Map<? extends K,? extends V> v);
+ 方法:
* void clear();
- 清除所有键值对
* boolean containsKey(Object key);
* boolean containsValue(Object value);
* Set<Map.Entry<K,V>> entrySet();
* void forEach(BiConsumer<? super K,?super V> action);
* V get(Object key);
- 根据key获得value,如果该key不存在,则返回null
* V getOrDefault(Object key,V defaultValue);
- 返回key对应的vlaue,如果不存在这个key,则返回defaultValue
* boolean isEmpty();
* Set <K> keySet();
- 返回所有key的Set集合
* V put(K key,V value);
- 添加键值对
* void putAll(Map<? extends K,? extends V> m);
* V remove(Object key);
- 如果存在该key,则删除该key的键值对,并返回被删除的value
* boolean remove(Object key,Object value);
* V replace(K key,V value);
* boolean replace(K key,V oldValue,V newValue);
* int size();
* Collection <V> values();

HashMap的特点

  • HashMap中的元素根据hashCode()值,而存储在特定位置,存储的顺序跟添加的顺序无关
  • 线程不安全,在多线程访问时,得用Collections.synchronizedMap(Map<K,V> map)转为线程安全的
  • HashMap可以用null作为key或者value,但因为key不能重复,因此最多只能有一个key为null,但value可以重复,可以有多个value

hashCode()、equals()与HashMap

  • hashCode()、equals()、compareTo()三个方法跟集合的关系都很紧密。

  • 比如要存入HashSet()中的对象的类都要重写hashCode()和equals()方法,并且要确保equals()返回true的两个对象的hashCode()值也要相等。

  • HashMap的key相等的判断标准:HashCode()值相等,并且equals()返回true

  • HashMap的value则只需要考虑equals()方法,equals()返回true,则说明两个value相等

  • 以上可见,HashMap的类的equals()、hashCode()的重写的原则,与HashSet一样

不可修改HashMap中的元素的key

  • 元素被添加进HashMap中后,原则上就不要修改了,至少不能修改影响hashCode()和equals()方法的实例,否则可导致访问到错误的对象、有些对象访问不到等等奇怪的错误

什么时候使用HashMap

LinkedHashMap

  • HashSet-->LinkedHashSet
  • HashMap-->LinkedHashMap
  • LinkedHashMap使用双向链表来维护key的添加次序,迭代的输出与添加顺序一致
  • 性能略低于HashMap

Properties

  • Java还有个古老的类:Hashtable,现在基本上被HashMap替代了,就不写了
  • 但它有个子类Properties却还得写
  • System类有个静态方法getProperties(),用来获取当前的系统属性,类型就是Properties
  • Properties的key和value都是String
  • 常见方法:
    • 构造方法:

      • Properties();
      • Properties(Properties defaults);
    • 方法:
      • String getProperty();
      • String getProperty(String key,String defaultValue);
      • Object setProperty(String key,String value);
      • void load(InputStream in);
      • void store(OutputStream out,String comments);
  • 示例:
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Properties; public class T1{
public static void main(String[] args) throws IOException{
Properties prop1=System.getProperties();
FileOutputStream fos=new FileOutputStream("E:\\Temp\\prop.ini");
prop1.store(fos,"system properties"); Properties prop2=new Properties();
prop2.load(new FileInputStream("E:\\Temp\\prop.ini"));
System.out.println(prop2);
}
}

WeakHashMap

  • WeakHashMap与HashMap的区别在于:

    • 前者对key是弱引用,而后者对key是强引用
    • 弱引用:如果没有别的强引用变量指向这些key对象,那么它们可能会被System.gc()回收
    • 强引用:即使没有别的引用变量指向这些key对象,它们也不会被System.gc()回收
  • 有哪些用途呢?
  • 参见:Java中关于WeakReference和WeakHashMap的理解
  • 示例代码:
import java.util.WeakHashMap;

public class T1{
public static void main(String[] args){
WeakHashMap whm=new WeakHashMap();
String en=new String("英语");
whm.put(new String("语文"),new String("优秀")); //匿名字符串,弱引用
whm.put(new String("数学"),new String("良好"));
whm.put(en,new String("及格")); //强引用
whm.put("Java",new String("优秀")); //字符串直接量,系统自动保留对其强引用
System.out.println(whm);
System.gc();
System.runFinalization();
System.out.println(whm); //只输出"英语"和"Java"两个键值对
}
}

IdentityHashMap

  • 这个类也跟HashMap相似,只是它判断两个key相等的标准是obj1==obj2,也就是内存中的相同地址
  • 因此可以存入两个"看起来相同"的key
  • 示例代码:
import java.util.IdentityHashMap;
import java.util.WeakHashMap; public class T1{
public static void main(String[] args){
IdentityHashMap ihm=new IdentityHashMap();
System.out.println(ihm.put(new String("语文"),90));
System.out.println(ihm.put(new String("语文"),95)); //这两个"语文"位于堆内存中,地址不一样
System.out.println(ihm.put("java",99));
System.out.println(ihm.put("java",96)); //这两个"java"位于常量池中,是同一个对象,地址相同
System.out.println(ihm);
}
}

其他

  • HashMap有个内部类,暂不写

0014 Java学习笔记-集合-HashMap集合的更多相关文章

  1. Java学习笔记27(集合框架一:ArrayList回顾、Collection接口方法)

    集合:集合是java中提供的一种容器,可以用来存储多个数据 集合和数组的区别: 1.数组的长度是固定的,集合的长度是可变的 2.集合中存储的元素必须是引用类型数据 对ArrayList集合的回顾 示例 ...

  2. Java学习笔记-基础语法Ⅶ-集合

    集合 集合类特点:提供一种存储空间可变的存储模型,存储的数据容量可以随时发生改变 这里需要回顾一下,因为数组和字符串一旦创建,就不可改变,需要区分一下 import java.util.ArrayLi ...

  3. 【Java学习笔记】Map集合的keySet,entrySet,values的用法例子

    import java.util.Collection; import java.util.HashMap; import java.util.Iterator; import java.util.M ...

  4. Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)

    规则: 1.54张扑克牌,有花色 2.顺序打乱,一人一张依次发牌,一人17张,留三张作为底牌 3.看牌:按大小王2A....43的序排列打印 示例: package demo; import java ...

  5. Java学习笔记32(集合框架六:Map接口)

    Map接口与Collection不同: Collection中的集合元素是孤立的,可理解为单身,是一个一个存进去的,称为单列集合 Map中的集合元素是成对存在的,可理解为夫妻,是一对一对存进去的,称为 ...

  6. Java 学习笔记 两大集合框架Map和Collection

    两大框架图解 Collection接口 由第一张图,我们可以知道,Collection接口的子接口有三种,分别是List接口,Set接口和Queue接口 List接口 允许有重复的元素,元素按照添加的 ...

  7. Java学习笔记33(集合框架七:Collections工具类)

    数组有工具类,方面操作数组 集合也有工具类:Collections 常用方法示例: package demo; import java.util.ArrayList; import java.util ...

  8. Java学习笔记31(集合框架五:set接口、哈希表的介绍)

    set接口的特点: 1.不包含重复元素 2.set集合没有索引,只能用迭代器或增强for循环遍历 3.set的底层是map集合 方法和Collection的方法基本一样 set接口的实现类HashSe ...

  9. Java学习笔记30(集合框架四:List接口)

    List接口继承自Collection接口 具有重要的三大特点: 1.有序集合:存入和取出的顺序一致 2.此接口的用户可以对列表中每个元素插入位置精确的控制:可以通过索引操作 3.可以存储重复元素 L ...

随机推荐

  1. 2015暑假多校联合---CRB and His Birthday(01背包)

    题目链接 http://acm.split.hdu.edu.cn/showproblem.php?pid=5410 Problem Description Today is CRB's birthda ...

  2. JS疑难点和GC原理

    js解析与序列化json数据(一)json.stringify()的基本用法: 对象有两个方法:stringify()和parse().在最简单的情况下,这两个方法分别用于把JavaScript对象序 ...

  3. 左求值表达式,堆栈,调试陷阱与ORM查询语言的设计

    1,表达式的求值顺序与堆栈结构 “表达式” 是程序语言一个很重要的术语,也是大家天天写的程序中很常见的东西,但是表达式的求值顺序一定是从左到右么? C/C++语言中没有明确规定表达式的运算顺序(从左到 ...

  4. Redis学习笔记2-使用 Redis 作为 LRU 缓存

    当 Redis 作为缓存使用时,当你添加新的数据时,有时候很方便使 Redis 自动回收老的数据.LRU 实际上是被唯一支持的数据移除方法.Redis 的 maxmemory 指令,用于限制内存使用到 ...

  5. 解决Wireshark没有网卡问题

    wireshark在mac上使用没有网卡问题直接在终端输入命令:sudo chmod 644 /dev/bpf*

  6. Visual Studio Code 使用 ESLint 增强代码风格检查

    前言 在团队协作开发中,为了统一代码风格,避免一些低级错误,应该设有团队成员统一遵守的编码规范.很多语言都提供了Lint工具来实现这样的功能,JavaScript也有类似的工具:ESLint.除了可以 ...

  7. 来自 Codrops 的7种创新的拖放交互界面

    Codrops 分享了一些界面拖放的交互设计想法.基本的思路是在拖动一个项目的时候,为特定的操作呈现出可投掷的区域.这节省了大量的界面空间 ,并给出了一个有趣的动态的互动.有很多应用场景,例如分类和组 ...

  8. 推荐12个最好的 JavaScript 图形绘制库

    众多周知,图形和图表要比文本更具表现力和说服力.图表是数据图形化的表示,通过形象的图表来展示数据,比如条形图,折线图,饼图等等.可视化图表可以帮助开发者更容易理解复杂的数据,提高生产的效率和 Web  ...

  9. 25条来自 Google 的移动网站设计准则

    越来越的用于通过移动设备访问网络,因此对于企业来说,现在比以往任何时候都更需要一个移动网站.但是,怎么样才能制作一个优秀的移动网站呢? 为了回答这个问题,Google 与 AnswerLab 合作,研 ...

  10. swift学习笔记之-属性

    //属性 import UIKit //属性(Properties)详解 /* 存储属性(Stored Properties):类.结构体中,不能在枚举中 计算属性(Computed Properti ...