HashMap源码中一个算法tableSizeFor
2019-01-05 13:09:58来源:博客园 阅读 ()
阅读JDK1.8版本HashMap源码看到的一段代码,返回大于等于指定入参的最小2的幂。
1 /** 2 * The maximum capacity, used if a higher value is implicitly specified 3 * by either of the constructors with arguments. 4 * MUST be a power of two <= 1<<30. 5 */ 6 static final int MAXIMUM_CAPACITY = 1 << 30; 7 8 /** 9 * Returns a power of two size for the given target capacity. 10 */ 11 static final int tableSizeFor(int cap) { 12 int n = cap - 1; 13 n |= n >>> 1; 14 n |= n >>> 2; 15 n |= n >>> 4; 16 n |= n >>> 8; 17 n |= n >>> 16; 18 return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1; 19 }
int n = cap-1;防止入参本身为2的幂,若不进行减一操作,结果将得到本身的2倍;
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Java集合类的那点通俗的认知
- 作为一个面试官,我想问问你Redis分布式锁怎么搞? 2020-06-10
- 你说研究过Spring里面的源码,循环依赖你会么? 2020-06-09
- 我可真是醉了,一个SpringBoot居然问了我30个问题 2020-06-08
- 通俗理解spring源码(六)—— 默认标签(import、alias、be 2020-06-07
- java对象指向问题 2020-06-07
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash