```java static final int DEFAULT_INITIAL_CAPACITY = 1 << 4; // aka 16 ``` 默认的 table 容量,1<<4 = 2^4 = 16,规定必须是2的幂。 ```java static final int MAXIMUM_CAPACITY = 1 << 30; ``` 最大的 table 容量,规定必须是 2 的幂,类型为 int,掐指一算,那只能是 0100 0000 0000 0000 0000 0000 0000 0000。因为 Java中 int 有 32 位,除第 1 位符号位外,数值部分只有 31 位,只有 1<<30 满足条件。 > 这里需要说明一下,对于 2 的幂,在计算机的世界里是一群特殊的存在,它们的二进制中只有一个1,其余位全为 0 。这个特性会影响与它进行位运算后的结果具有一些特殊效果。 ```java static final float DEFAULT_LOAD_FACTOR = 0.75f; ``` 构造函数中未指定时使用的负载因子。 ```java static final int TREEIFY_THRESHOLD = 8; ``` 相信很多人知道链表长度大于 8 会转为红黑树,依据也就是这个字段的注释说明。但其实这只是条件之一,另一个条件就是下面这个参数。 ```java static final int MIN_TREEIFY_CAPACITY = 64; ``` 在进行链表转红黑树的时候,第一步是检查链表的长度是否大于等于 8,第二步会检查 table 数组的容量是否小于此数值,若小于,则取消转为红黑树,只对 table 数组进行扩容。 ```java static final int UNTREEIFY_THRESHOLD = 6; ``` 当键值对数量过多时需要对 table 数组进行扩容,并且将每个键值对放到新的桶中(或者不变)。原来的桶的内部结构有可能是链表,也有可能是红黑树,经过一番洗牌之后,如果桶结构为红黑树的键值对数量过低,就会重新转变为链表。低到哪个程度呢?就是这个字段对应的大小。