判断一个数是否是二的整数幂

方法1

a & (a-1) == 0,画图就能理解

方法2

这个是在看netty源码的时候发现的,DefaultEventExecutorChooserFactory#isPowerOfTwo(int val)

(a & -a) == a,-a二进制的计算方式是,a的二进制取反,再加1,画图方便理解

 

posted @ 2021-06-17 18:47  walker993  阅读(51)  评论(0编辑  收藏  举报