当前位置: 首页 > news >正文

茂名网站制作价格网站一键生成

茂名网站制作价格,网站一键生成,褚明宇wordpress,重生做网站的小说HashMap是Java语言中的一个重要数据结构,它实现了Map接口,允许我们存储键值对,并且可以根据键直接访问对应的值。 特性 键值对存储:HashMap存储的是键值对数据,可以方便的通过键来获取值。无序:HashMap中…

HashMap是Java语言中的一个重要数据结构,它实现了Map接口,允许我们存储键值对,并且可以根据键直接访问对应的值。

特性

  1. 键值对存储:HashMap存储的是键值对数据,可以方便的通过键来获取值。
  2. 无序:HashMap中的元素没有顺序,每次输出的顺序都可能不一样。这是因为HashMap内部是通过哈希表来实现的,元素存储在哈希表中,其位置取决于键的哈希值。
  3. 允许null键和null值:HashMap允许一个null键和一个null值。
  4. 扩容:当HashMap中的元素数量达到一定的阈值(默认是桶(bucket)的个数,每个桶是一个链表或者红黑树)时,会进行扩容,扩容会导致原有的数据重新计算哈希值并重新放置

HashMap的工作原理

HashMap的工作原理主要涉及以下几个部分:

  1. 哈希函数:当我们将键值对插入到HashMap中时,HashMap会使用哈希函数(hash function)将键(key)转换成一个哈希码(hash code),这个哈希码用来确定键值对应该放在哪个桶(bucket)中。
  2. 桶和链表:在HashMap中,每个桶都是一个链表,链表中的每个节点都包含一个键值对。如果多个键哈希到同一个桶,那么这些键值对就会在链表中顺序存储。
  3. 扩容和再哈希:当某个桶中的链表长度超过一个阈值(例如8)时,HashMap会将这个桶拆分成两个或更多的桶,这个过程就叫做扩容。扩容会使得HashMap的内部数据结构发生变化,可能会导致查询性能下降。
  4. 红黑树:当某个桶中的链表长度超过一定阈值(例如16)时,链表会转化成红黑树以提高查询效率。

源码

public class HashMap<K,V> extends AbstractMap<K,V>  implements Map<K,V>, Cloneable, Serializable {  // 其他常量  /**  * The default initial capacity - MUST be a power of two.  */  static final int DEFAULT_INITIAL_CAPACITY = 16;  /**  * The load factor used when none specified in constructor.  */  static final float DEFAULT_LOAD_FACTOR = 0.75f;  /**  * The table, resized as necessary. Length MUST Always be a power of two.  */  transient Node<K,V>[] table;  /**  * The number of key-value mappings contained in this map.  */  transient int size;  /**  * The next size value at which to resize (capacity * load factor).  */  transient int threshold;  /**  * The load factor for the hash table.  When the capacity is multiplied by  * this factor, it is incremented.  */  transient float loadFactor;  // 其他变量和方法  
}

其中,HashMap的核心是它的哈希表(由table数组实现),每个元素都是一个Node对象,其中包含键值对。HashMap还维护了一些其他变量,如size(映射数量)、threshold(下一次扩容的阈值)和loadFactor(哈希表的加载因子)。

HashMap的主要方法包括:构造函数、put(插入键值对)、get(获取键对应的值)、remove(删除键值对)、isEmpty(判断是否为空)等。其中,put和get方法是HashMap中最常用的方法,它们的实现涉及到哈希表的查找和插入操作。以下是put方法的源码:

public V put(K key, V value) {  return putVal(hash(key), key, value, false, true);  
}  final V putVal(int hash, K key, V value, boolean onlyIfAbsent, boolean evict) {  Node<K,V>[] tab; Node<K,V> p; int n, i;  if ((tab = table) == null || (n = tab.length) == 0)  n = (tab = resize()).length;  if ((p = tab[i = (n - 1) & hash]) == null) { // ①如果哈希表为空,将当前元素插入到第一个位置。p为null。则直接在第一个位置插入元素。同时n++。  tab[i] = new Node<>(hash, key, value, null); // 创建新的节点插入到哈希表中。同时n++。如果超过阈值,则进行扩容。并重新计算哈希值和位置。并将元素插入到新的位置中。同时n++。如果超过阈值,则进行扩容。并重新计算哈希值和位置。
}}

如果哈希表已经满了,那么会进行扩容,即创建一个新的哈希表,大小是原来的两倍,并将原来哈希表中的所有元素重新插入到新的哈希表中。扩容会导致性能的损失,因为每次插入操作都需要重新计算元素的哈希值和位置。因此,在设计HashMap时,需要考虑哈希表的大小和加载因子,以平衡性能和内存使用。

在插入元素时,如果哈希表中已经存在相同的哈希值,那么会进行冲突处理。HashMap采用链表或红黑树来处理冲突。当冲突发生时,会将当前元素插入到链表的尾部或红黑树的叶节点上。当链表的长度超过一定阈值(如8)时,会将链表转换为红黑树,以提高查询效率。

在查询元素时,HashMap会根据给定的键计算出哈希值,并找到对应的桶。然后,在该桶中查找链表或红黑树,直到找到对应的元素或到达链表的尾部或红黑树的叶节点。如果找不到指定的元素,则返回null。

总之,HashMap是一种高效的键值对存储数据结构,通过哈希表实现了O(1)时间复杂度的插入、删除和查询操作。但是,由于哈希表的不确定性,HashMap不支持线程安全。如果需要线程安全,可以使用ConcurrentHashMap或者通过Collections.synchronizedMap方法将Map包装为线程安全。

除了基本的操作,HashMap还提供了其他一些有用的方法,例如:

  1. containsKey(Object key):判断指定键是否在Map中,存在则返回true。
  2. containsValue(Object value):判断指定值是否在Map中,存在则返回true。
  3. get(Object key):返回指定键对应的值,如果键不存在则返回null。
  4. putAll(Map<? extends K,? extends V> m):将指定Map中的所有映射复制到此Map中。
  5. remove(Object key):移除指定键及其关联的值。
  6. size():返回Map中键-值映射关系的数量。
  7. isEmpty():测试此Map是否为空。
  8. keys():返回包含此映射中所有键的迭代器。
  9. values():返回包含此映射中所有值的迭代器。
  10. entrySet():返回包含此映射中所有映射关系的Set视图。

此外,HashMap还提供了其他一些参数来控制其行为,如初始容量、加载因子等。可以通过构造函数或者相关方法来设置这些参数。

总之,HashMap是一个非常实用的数据结构,适用于需要快速查找和插入键值对的情况。但是,需要注意的是,由于HashMap的不线程安全性,如果在多线程环境下使用,可能会导致数据的不一致性问题,需要使用线程安全的数据结构或者通过Collections.synchronizedMap方法进行包装。

http://www.ritt.cn/news/2064.html

相关文章:

  • 新网站提交百度收录seo刷关键词排名工具
  • wordpress分类添加htmlseo博客推广
  • 深圳市企业网站seo营销工具重庆seo技术博客
  • 网站服务器租用还是托管呢武汉全网营销推广公司
  • 网页兼容性站点seo产品是什么意思
  • 玉溪网站建设制作美国今天刚刚发生的新闻
  • 做一网站要什么个人怎么做网站
  • 网站建设公司考察域名备案查询
  • 青岛微网站开发百度云搜索引擎入口
  • wordpress建设购物网站百度官方优化软件
  • 影响网站排名的因素 权重小程序开发哪家更靠谱
  • 拦截WordPress请求南京谷歌seo
  • 网络架构和网络拓扑的区别中山seo
  • 想自己做网站需要会什么软件推广联盟平台
  • 辽宁网站建设多少钱推广优化网站
  • 河源wordpress培训百度seo点击工具
  • 做网站app公司前景线上直播营销策划方案
  • 网站建立后被别人点击要付钱吗优化人员配置
  • 团购鲜花的网站建设找人帮忙注册app推广
  • 网站开发武汉公司成都有实力的seo团队
  • 网站建设的利益如何推广软件
  • 禹城网站设计百度识图查另一半情头
  • 汾阳做网站大数据精准营销系统
  • 东莞市网络优化推广服务机构嘉兴seo外包平台
  • 简述电子商务网站的建站流程百度极速版推广员怎么申请
  • 写作网站新手百度指数代表什么意思
  • 别人怎么看见我做的网站软件培训机构
  • 兰州网站建设价韩国最新新闻
  • 手机网站优化技巧网站建设一般多少钱
  • 一流的网站建设公司360seo