PromisingGirl-Du 2020-05-29 10:27 采纳率: 0%
浏览 697

我想请问一下这个 1 << 4的左位移是如何计算得16的

查看JDK hashMap的扩容机制发现用的是位移,但是我不知道是怎么计算才得出来的。所以还请大神帮我解答,感激不尽!

static final int DEFAULT_INITIAL_CAPACITY = 1 << 4; // aka 16(16 = 2^4)
  • 写回答

2条回答 默认 最新

  • niaonao 优质创作者: Java技术领域 2020-05-29 10:34
    关注

    位运算符,是二进制操作,左移一位相当于原数乘2倍。
    000001左移一位000010,左移4位010000

    000001转十进制
    = 0*2^5 + 0*2^4 + 0*2^3 + 0*2^2 + 0*2^1 + 1*2^0
    = 0 + 0 + 0 + 0 + 0 + 1
    = 1
    010000转十进制
    = 0*2^5 + 1*2^4 + 0*2^3 + 0*2^2 + 0*2^1 + 0*2^0
    = 0 + 16 + 0 + 0 + 0 + 0
    = 16

    评论

报告相同问题?