java 哈希 key 为 null_浅谈HashMap、HashTable的key和value是否可为null

结论:

HashMap对象的key、value值均可为null。

HahTable对象的key、value值均不可为null。

且两者的的key值均不能重复,若添加key相同的键值对,后面的value会自动覆盖前面的value,但不会报错。

public class Test {

public static void main(String[] args) {

Map map = new HashMap();//HashMap对象

Map tableMap = new Hashtable();//HashTable对象

map.put(null, null);

System.out.println("hashMap的[key]和[value]均可以为null:" + map.get(null));

try {

tableMap.put(null, "3");

System.out.println(tableMap.get(null));

} catch (Exception e) {

System.out.println("【ERROR】:hashTable的[key]不能为null");

}

try {

tableMap.put("3", null);

System.out.println(tableMap.get("3"));

} catch (Exception e) {

System.out.println("【ERROR】:hashTable的[value]不能为null");

}

}

}

运行结果:

hashMap的[key]和[value]均可以为null:null

【ERROR】:hashTable的[key]不能为null

【ERROR】:hashTable的[value]不能为null

补充知识:hashmap判断是否存在key时,使用get(key)==null判断还是containsKey?

java中hashmap(key,value)的key和value都可以是null

我们看hashmap中get()和containskey()的方法:

public V get(Object key) {

Node

结论

如果java程序对 key不存在和key存在但是存的值是null这两种情况处理相同一视同仁,则可以直接使用

T t = map.get(key);

if(t==null){

//key不存在,或者存的值是null

}else{

//key存在

}

代替:

if(map.containskey(key)){

//key 存在

}else{

//不存在

}

T t = map.get(key);

if(t==null){

//存的值是null

}

如果java程序需要区分存的值是null和key不存在这两种情况,则需要使用:

if(map.containskey(key)){

//key 存在

}else{

//不存在

}

T t = map.get(key);

if(t==null){

//存的值是null

}

以上这篇浅谈HashMap、HashTable的key和value是否可为null就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
区别 HashMapHashtable: 1. 线程安全性:Hashtable 是线程安全的,HashMap 不是线程安全的。 2. Null 值:Hashtable 不允许 null 键和 null 值,而 HashMap 允许一个 null 键和多个 null 值。 3. 迭代器:Hashtable 的迭代器是 enumerator,而 HashMap 的迭代器是 Iterator。 4. 初始容量和扩容:Hashtable 的初始默认容量是 11,加载因子为 0.75,而 HashMap 的初始默认容量是 16,加载因子为 0.75。 区别 HashMap 和 LinkedHashMap: 1. 插入顺序和访问顺序:LinkedHashMapHashMap 的基础上维护了一个双向链表,用来维护插入顺序或者访问顺序。可以根据插入顺序或者访问顺序来遍历 map。 2. 性能:LinkedHashMap 的插入、删除和定位性能略低于 HashMap,但是迭代访问时性能不受影响。 HashMap 的底层实现: 1. new HashMap() 会调用默认的构造函数,将初始容量设置为 16,负载因子设置为 0.75。 2. put(key, value) 方法先通过 key 的 hashCode() 方法计算出哈希值,然后通过哈希值和 HashMap 的长度计算出槽的索引位置,如果该位置没有元素,则直接插入到该位置。如果该位置已经有元素,则使用 equals() 方法判断 key 是否相等,相等则覆盖 value,否则以链表形式插入到该位置。如果链表长度超过了阈值(默认为 8),则将链表转化为红黑树,加速查找速度。当 HashMap 的元素数量超过了容量和负载因子的乘积时,会自动扩容、重新计算哈希值存储位置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值