拿3来做个例子,它在二进制中是这样的:00000000 00000000 00000000 00000011
这时,我如果想要改变它的从右往左第6位二进制,把它改成1,我该怎么做呢。
我们可以给第6位二进制‘或’(|)1,就可以得到我们想要的了。也就是让原来的式子与下面这串二进制进行‘或’运算
00000000 00000000 00000000 00100000
那如何得到这串二进制呢,想想看,我们这串数字其实可以通过1<<5(‘1’向左移动5位)得到
然后再让这串二进制和前面的3进行‘或’运算,就得到我们要的结果了
用代码实现,就是这样:
接下来又有一个问题,我们怎么把这个值变回去呢
我们现在的数字是:00000000 00000000 00000000 00100011
原来的数字: 00000000 00000000 00000000 00000011
对照式子,我们其实只要对现在的式子和下面这串数字进行‘与’运算就可以了
11111111 11111111 11111111 11011111
那么这串数字怎么得到呢?我们可以通过我们上个题目中的“1<<5”再取反得到
用代码写,就是这样: