首页 > 其他 > 详细

用异或代替按位求反

时间:2017-06-26 23:34:26      阅读:415      评论:0      收藏:0      [点我收藏+]

按位取反,意思是原来的每一位,1变0,0变1。

按照这个1变0,0变1的标准,若求x的按位取反值,可以用求异或来替代。

异或的本质是模二加,效果是相同为1,相异为0。

对于x = 10101,想要用异或来达到按位取反的效果,就得找出一个特殊的数。令这个数为y,有:

    10101
^         y
_________
    01010

可以发现,y只能是11111,即和x的二进制位数相等的全1。

即若x为一个32位的数,则有 ~x = x ^ 0xffffffff。

 

写代码的时候出现了一些“奇怪”的事情。在vc6.0中有:

;int a = 3;
mov         dword ptr [ebp-0Ch],3

;int b = a ^ 0xffffffff;
00405027   mov         ecx,dword ptr [ebp-0Ch]
0040502A   xor         ecx,0FFh
0040502D   mov         dword ptr [ebp-14h],ecx

源代码给的是0xffffffff,但汇编代码中出现是0xff,只有8位,而且计算结果是对的。

如果只是让a和0xff相异或的话,结果肯定不对。

这里把源代码的0xffffffff换成-1,则有:

;b = a ^ -1;
mov         ecx,dword ptr [ebp-0Ch]
xor         ecx,0FFh
mov         dword ptr [ebp-14h],ecx

看来这里应该是用0xff代表-1,并对0xff进行了扩展变为0xffffffff,否则结果不对。

但是源代码直接写0xff或0xffff看来是不行的。

用异或代替按位求反

原文:http://www.cnblogs.com/rdt2017/p/7082750.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!