a&(-a) 什么意思 C语言的
4个回答
展开全部
按位与因为数字在电脑中是以补码的形式存在的。
例如:
a-=a的意思为a=a-a,先用a减a,再将得到的结果赋值给a。-=实际上是一种缩写形式,使得对变量的改变更为简洁。
运算时,可以将其写成熟悉的形式,从右向左依次计算,注意在每次计算时,变量的值会发生改变, 如不注意,就会导致错误的情况发生。
扩展资料:
求负整数的补码,将其原码除符号位外的所有位取反(0变1,1变0,符号位为1不变)后加1。
同一个数字在不同的补码表示形式中是不同的。比如-15的补码,在8位二进制中是11110001,然而在16位二进制补码表示中,就是1111111111110001。以下都使用8位2进制来表示。
例:求-5的补码。
-5对应正数5(00000101)→所有位取反(11111010)→加00000001(11111011)
所以-5的补码是11111011。
参考资料来源:百度百科-补码
展开全部
按位与
因为数字在电脑中是以补码的形式存在的
比如
a = 10
仅以8位举例
正数
a 原码 0000 1010 补码与原码相等 0000 1010
负数 补码为 它绝对值的反码最后+1
-a 补码 a的反码 11110101 最后+1 1111 0110
再进行按位与操作 结果为 0000 0010 转换成整型 就是 2
因为数字在电脑中是以补码的形式存在的
比如
a = 10
仅以8位举例
正数
a 原码 0000 1010 补码与原码相等 0000 1010
负数 补码为 它绝对值的反码最后+1
-a 补码 a的反码 11110101 最后+1 1111 0110
再进行按位与操作 结果为 0000 0010 转换成整型 就是 2
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
lowbit
就是二进制数低位连续的0加上一个1组成的数
也可以理解成一个数由2构成的最大约数
比如 20
转换成二进制就是10100(2) 最低位有2个0 那20&(-20)就是100(2),就是4
原理是 c里面一个数的相反数用补码表示 自己查吧 ..
就是二进制数低位连续的0加上一个1组成的数
也可以理解成一个数由2构成的最大约数
比如 20
转换成二进制就是10100(2) 最低位有2个0 那20&(-20)就是100(2),就是4
原理是 c里面一个数的相反数用补码表示 自己查吧 ..
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
C里面没见过这个,你确定编译通过了嘛?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询