对于这个问题来说,我们首先想到的肯定是通过按位操作符,通过按位操作符,在逻辑上建立0和1的关系,从而可以改变其中的某一位。
我们建立一个二进制数7,它在内存中的储存方式为补码形式,即0...0111(后四位为0111,其余为0)。我们想改变它的倒数第二位为0,那么,可以从以下的角度去思考:
1,利用按位与操作符“&”,与的二进制对象前面都为0,后四位为1101,这样,没有改变其他位的值,只是改变了我们要求改变的,则代码如下:
#include<stdio.h>
int main()
{
int x = 7;
x = x & 13;
printf("%d\n",x);
return 0;
}
(当然,可以发现作者的题目很有趣,你利用结果5当作二进制对象也可以把结果算出来,我只能说我刚开始出题的时候没过脑子好吧~)
输出结果即是5(13为我们所创建的二进制对象代表的十进制数,结果则是改变后四位为0101之后所代表的十进制数)
当然,当我们想变回来的时候,就要用相反的逻辑操作,去实现结果。思考的流程为:
此时x所对应的是0...0101,我们想把倒数第二位变为1,其他位又不能动,那么可以再通过按位或操作符,0...0010为现在的二进制对象。那么,也可以实现出来。
2,优化代码:
我们在创建二进制对象的时候,有时候如果逻辑复杂,会不是那么容易就可以把对象创建出来的,所以,我们应该通过其他的方法去创建这个二进制对象--取反+移位操作符。
因为1的二进制数很容易就可以想到,所以我们就通过1来实现上述代码。
上述第一次操作的时候,我们只需让倒数第二位为0,其余都为1,也就是1...1101,那么我们可以把1的二进制数中末尾的1向左移动一位,然后按位取反,就可以得到我们想要的这个二进制对象了。代码实现如下:
#include<stdio.h>
int main()
{
int x = 7;
x = x & ~(1 << 1);
printf("%d\n",x);
return 0;
}
这样,算出来的结果和上面的一模一样,同时,下面优化的代码就不需要我们怎么去计算二进制数,直接利用1就可以表示出来了。
同理,我们如果想从后往前还原7,那么也可以先将1左移一位,然后直接通过逻辑或的操作,还原7。
合理利用操作符,会使代码变得更加之简便!