最近在看HashMap的源码时,发现<<符号
简单粗暴的解释为:左边的数字*2的右边的数字的几次方
上面的1 << 4 计算的结果为 1 * 2^4 也就是 16
原理解释
参考https://zhidao.baidu.com/question/177525577.html
<<:是逻辑左移,右边补0,符号位和其他位一样要移动;同理:>>是逻辑右移,左边补0,符号位和其他位一样要移动。
例如: 3 << 2,则是将数字3左移2位
计算过程:3 << 2
首先把3转换为二进制数字0000 0011,然后把该数字高位(左侧)的两个零移出,其他的数字都朝左平移2位,最后在低位(右侧)的两个空位补零。则得到的最终结果是0000 1100,则转换为十进制是12
数学意义:
在数字没有溢出的前提下,对于正数和负数,左移一位都相当于乘以2的1次方,左移n位就相当于乘以2的n次方。