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

交易平台网站建设策划书百度推广seo怎么学

交易平台网站建设策划书,百度推广seo怎么学,网站内链404 not found,单页网站开发实例下载1、本人博客《HashMap、HashSet底层原理分析》 2、本人博客《若debug时显示的Hashmap没有table、size等元素时,查看第19条》 结论 1、链表长度大于8时(插入第9条时),会触发树化(treeifyBin)方法,但是不一定会树化,若数组大小小于…

1、本人博客《HashMap、HashSet底层原理分析》
2、本人博客《若debug时显示的Hashmap没有table、size等元素时,查看第19条》

结论

1、链表长度大于8时(插入第9条时),会触发树化(treeifyBin)方法,但是不一定会树化,若数组大小小于64时,则会先扩容。
2、假设扩容后该链表重新计算Hash后还是放在同一个数组下标时,则会出现链表长度大于8时,未树化的情况。

jdk8源码(treeifyBin)

final void treeifyBin(Node<K,V>[] tab, int hash) {int n, index; Node<K,V> e;// MIN_TREEIFY_CAPACITY = 64// 链表长度小于64时会优先扩容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);}
}

测试源码(大于8时,未树化)

import java.util.HashMap;
import java.util.Objects;public class HashmapTest {public static void main(String[] args) {HashMap<User,User> hashMap = new HashMap<>();// 同一链表插入8条for (int i = 0; i < 8; i++) {hashMap.put(new User("张三", 18),new User("张三", i));}// 插入第九条,链表长度大于8,会进入treeifyBin树化方法,但是未树化,会执行扩容方法// 默认数组大小16扩容到32// 链表长度变成了9个Node节点,并非红黑树hashMap.put(new User("张三", 18),new User("张三", 9));// 插入第10条,链表长度大于8,会进入treeifyBin树化方法,但是未树化,会执行扩容方法// 数组大小由32扩容到了64// 链表长度变成了10个Node节点,并非红黑树hashMap.put(new User("张三", 18),new User("张三", 10));// 插入第十一条时树化// 数组容量还是64未触发扩容// 链表变成红黑树,节点由Node变成TreeNodehashMap.put(new User("张三", 18),new User("张三", 11));}
}// 重写hashCode方法,保证值一样是hashcode是一样的,可以使值一样的对象出现在同一链表上
class User{private String name;private int age;public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public User(String name, int age) {this.name = name;this.age = age;}@Overridepublic String toString() {return "User{" +"name='" + name + '\'' +", age=" + age +'}';}@Overridepublic int hashCode() {return Objects.hash(name, age);}
}

插入第九条时的Hashmap
插入第十条时结果是一样的,只是数组扩容到了64
1、数组长度扩容到了32
2、Hashmap中保存了9个数据,均在同一条链表
3、节点为Node节点,并不是treenode(红黑树)
在这里插入图片描述
插入第十一条时的Hashmap
1、数组大小为64
2、节点变成了treenode(红黑树)
在这里插入图片描述

测试源码(大于8时,树化)

初始化Hashmap时,直接大于等于64,则同一个链表插入第九条时直接执行了树化。
treeifyBin方法中只有数组长度小于64时才会执行扩容方法,否则则是树化

// 初始化大小,其他同上,插入第九条时,节点就变成了treenode
HashMap<User,User> hashMap = new HashMap<>(64);

插入第九条时的Hashmap
1、数组大小为64
2、节点变成了treenode(红黑树)
在这里插入图片描述

http://www.zhongyajixie.com/news/25701.html

相关文章:

  • 双语网站建设定制开发百度热搜榜排名今日
  • 做室内装修设计的网站长沙网站优化排名推广
  • 手机网站制作视频教程深圳互联网推广公司
  • 顶级设计网站推荐全国防疫大数据平台
  • 南宁网站如何制作临沂seo推广外包
  • 南京建设工程交易中心网站码迷seo
  • 外贸网站如何推广国外搜索引擎网站
  • 怎么用mvc架构做网站开发小程序
  • 商城购物网站开发背景哪个行业最需要推广
  • 深圳网站策划公司网络建站
  • 内江网站建设网站关键词排名优化推广软件
  • 代做ppt网站好seo赚钱培训课程
  • 广东做淘宝的都在哪里网站如何做好线上营销
  • 网站优化的链接建设网络推广网站的方法
  • 网站开发小组郑州seo服务
  • vue 做双语版网站宁德市地图
  • 四川阿坝建设招标网站网站推广的目的是什么
  • 可以做宣传海报的网站网站如何快速收录
  • 深交所大宗交易平台台州seo排名扣费
  • 自己如何安装wordpressseo短视频网页入口引流网站
  • 北京微信网站设计费用seo知识总结
  • 网站的困难百度系app
  • 邢台网站推广网页制作模板
  • 做网站设计需要什么技术西安seo哪家好
  • WordPress无法下单北京谷歌优化
  • 四川网站制作哪家好西安百度百科
  • 公司网站服务器优化百度安装app
  • 武汉网站seo靠谱企业网络规划设计方案
  • 网站定制开发公司推荐百度关键词竞价排名
  • 用花生壳免费域名做公司网站成都网站seo设计