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

网站微信收款二维码怎么做2008iis添加网站打不开

网站微信收款二维码怎么做,2008iis添加网站打不开,网站细节,凡客网站目录优化深入剖析 HashMap:内部结构与性能优化 引言 HashMap 是 Java 集合框架中的核心类,广泛应用于数据存储和检索场景。本文将深入剖析其内部结构,包括数组、链表和红黑树的转换机制,帮助读者理解其工作原理和性能优化策略。 1. Hash…

深入剖析 HashMap:内部结构与性能优化

引言

HashMap 是 Java 集合框架中的核心类,广泛应用于数据存储和检索场景。本文将深入剖析其内部结构,包括数组、链表和红黑树的转换机制,帮助读者理解其工作原理和性能优化策略。


1. HashMap 的基本结构

1.1 数组(Array)

  • 作用:存储桶(bucket),每个桶可存放一个或多个键值对
  • 初始容量:默认 16,可通过构造函数自定义
  • 扩容机制:当元素数量超过阈值(capacity * loadFactor)时,数组扩容至原大小的两倍

1.2 链表(Linked List)

  • 触发条件:桶中元素数量超过阈值(默认 8)时使用链表存储
  • 特点
    • 插入/删除时间复杂度:O(1)
    • 查找时间复杂度:O(n)

1.3 红黑树(Red-Black Tree)

  • 触发条件
    • 链表长度 > 8
    • 数组容量 ≥ 64
  • 特点
    • 插入/删除/查找时间复杂度:O(log n)

2. 核心数据结构的使用

2.1 数组的索引计算

index = (n - 1) & hash
n:数组长度(容量)
hash:键的哈希值(通过扰动函数优化分布)

2.2 链表的实现

  • 节点结构

    static class Node<K,V> {final int hash;final K key;V value;Node<K,V> next;
    }
    /** 后续在 Node<K,V> 使用时被transient修饰, transient是 Java 中的一个关键字,用于修饰类的成员变量。被 transient 修饰的变量表示该变量不会被默认的序列化机制所保存。
    作用:阻止某个变量在对象序列化时被写入文件或传输。
    使用场景:当某些数据不需要被持久化(如敏感信息、临时数据等),可以使用 transient。*/
    

2.3 红黑树的实现

  • 节点结构

    static final class TreeNode<K,V> extends LinkedHashMap.Entry<K,V> {TreeNode<K,V> parent;TreeNode<K,V> left;TreeNode<K,V> right;TreeNode<K,V> prev;boolean red;
    }
    

3. 数据结构转换机制

3.1 链表 → 红黑树

条件

  1. 链表长度 > 8

    static final int TREEIFY_THRESHOLD = 8;
    
  2. 数组容量 ≥ 64

    static final int MIN_TREEIFY_CAPACITY = 64;
    

转换过程

// jdk1.8
final void treeifyBin(Node<K,V>[] tab, int hash) {int n, index; Node<K,V> e;if (tab == null || (n = tab.length) < MIN_TREEIFY_CAPACITY)resize(); // 优先扩容else if ((e = tab[index = (n - 1) & hash]) != null) {// 将链表节点转换为树节点TreeNode<K,V> hd = null, tl = null;do {TreeNode<K,V> p = replacementTreeNode(e, null);if (tl == null) hd = p;else {p.prev = tl;tl.next = p;}tl = p;} while ((e = e.next) != null);// 构建红黑树if ((tab[index] = hd) != null) hd.treeify(tab);}
}

3.2 红黑树 → 链表

条件:树节点数量 ≤ 6

static final int UNTREEIFY_THRESHOLD = 6;

转换过程

// jdk1.8
final Node<K,V> untreeify(HashMap<K,V> map) {Node<K,V> hd = null, tl = null;for (Node<K,V> q = this; q != null; q = q.next) {Node<K,V> p = map.replacementNode(q, null);if (tl == null)hd = p;elsetl.next = p;tl = p;}return hd;
}

4. 性能优化策略

4.1 哈希冲突优化

  • 扰动函数:通过二次哈希分散键值对分布

    static final int hash(Object key) {int h;return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
    }
    

4.2 容量设置策略

  • 初始容量:预估存储量,避免频繁扩容
  • 负载因子:默认 0.75,平衡时间与空间成本

4.3 扩容优化

  • 增量迁移:扩容时逐步迁移节点,避免长时间阻塞

5. 总结

结构触发条件时间复杂度适用场景
数组基础存储结构O(1) 索引访问元素均匀分布
链表桶中元素 ≤ 8O(n) 查找少量哈希冲突
红黑树桶中元素 >8 且容量 ≥64O(log n) 操作严重哈希冲突

关键点

  • 链表转树需同时满足长度和容量条件

  • 树转链表采用更保守的阈值(6)防止频繁转换

  • 合理的初始容量和负载因子可显著提升性能


文章转载自:

http://lNKXaskk.snLxb.cn
http://ZLojurZP.snLxb.cn
http://g2LsZsNh.snLxb.cn
http://sIJyHUc3.snLxb.cn
http://ku4extJr.snLxb.cn
http://VMC9QugL.snLxb.cn
http://b9mWePN8.snLxb.cn
http://xvBRxeJz.snLxb.cn
http://EVXSjwGF.snLxb.cn
http://qRqk0vY7.snLxb.cn
http://Hu5bPSCB.snLxb.cn
http://TQzh9uPT.snLxb.cn
http://4rpKl7iX.snLxb.cn
http://2ac41lTX.snLxb.cn
http://A9zvquGW.snLxb.cn
http://594N1AaT.snLxb.cn
http://Rk5ezsxH.snLxb.cn
http://wN30VKd9.snLxb.cn
http://3SBPZVbN.snLxb.cn
http://vgNOzsoH.snLxb.cn
http://KMg98Sua.snLxb.cn
http://e8li2qKL.snLxb.cn
http://uolleBac.snLxb.cn
http://vWzWyeVd.snLxb.cn
http://z3xmEiDd.snLxb.cn
http://DsrDRe6P.snLxb.cn
http://vwTKTNVM.snLxb.cn
http://MyAbj7YU.snLxb.cn
http://0TUcr7Nz.snLxb.cn
http://3i71V13y.snLxb.cn
http://www.dtcms.com/wzjs/754775.html

相关文章:

  • 扬州建设机械网站网站短信验证码接口怎么做
  • 太原做网站的公司排行wordpress 激活邮件
  • 长沙网站设计的公司江西做网站哪家好
  • dede打包好的网站怎么提取模板网页设计模板素材网站大全
  • 一个网站3个相似域名网站开发三大元素
  • 四省网站建设贷款网站源码html
  • 惠州 网站建设公司太原网页设计公司是销售吗
  • 惠州建设局官方网站ps和dw怎么做网站
  • 西安市沣东新城建设局网站平湖企业网站建设
  • 网站建设的知名品牌域名注册网站有哪些
  • 多少钱立案青岛百度seo排名
  • 网站搭建中企动力最行建设发展公司网站
  • 超全的开源建站系统大全影视广告公司网页设计
  • 一般做网站要多少钱邳州市建设局官方网站
  • 网站建设公司antnw怎么查看网页的源代码
  • 网站开发的人天津建设银行官网站首页
  • 网站建设 面试问题wordpress选定文字标红
  • 怎么做网站然后卖出去怎样建立一个自己的网站免费
  • 网站建设与制作段考试题湘潭大学迎新自助网站
  • 设计坞网站怎么样自己如何建设校园网站
  • 定制网站建设费用百度突然搜不到我的网站
  • seo网站结构如何优化WordPress表单制作教程
  • 哪个网站做推广比较好福州金山网站建设
  • 人力招聘网站建设超凡网络网站
  • 做网站外包公司名称微商系统软件开发
  • 公司网站建设全衡阳的网站建设
  • wordpress 制作网站模板教程网站开发的招标参数
  • 婚纱销售网站网站建设模板犀牛云
  • 企业做网站价格wordpress编辑器转义
  • 网站开发后怎么上线常州市经开区建设局网站