对于操作: x & -x, 其-x 在计算机存储是用x的补码存储即,~x + 1
x & - x = x & (~x + 1)
对于偶数:
这里对偶数10进行运算
x & -x = 0000 1010 & 1111 0110 = 0000 0010
即最大可以被2的1次方整除。
对于奇数:
这里对奇数7进行运算
x & -x = 0000 0111 & 1111 1001 = 00000001
只要是奇数结果都是1
结论:对于偶数: 求得是最大的2的k次方能整除这个数的数,即m = n & -n , 则 n % m = 0, 且 m = 2 ^ k,对于奇数,结果都是1.