1. 神奇的位操作
a. 作为学仪器仪表的工科生,C语言不仅提供了高级语言的便利,还保留了汇编语言级别的位处理机制,这使得C语言
成为编写设备驱动程序和嵌入式代码的首选
2. 二进制补码:
a. 负数的补码:将其原码除符号位外的所有位取反(0变1,1变0,符号位为1不变)后加1
3. C语言中的按位运算符
a. 按位逻辑运算符
i. 都用于整型数据,包括char
ii. 按位取反~
1) 1变0,0变1
a) val=10001000,~val=01110111
2) 该运算符不改变原数值的大小,而是创建了一个可以赋值和使用的新值
iii. 按位相与&
1) 逐位比较两个运算对象生成一个新值
2) 按位相与并赋值语句---&=
3) 与0相与即可清0
iv. 按位或|
1) 逐位比较两个运算对象生成一个新值
2) 按位或并赋值---|=
3) 与1相或即可置1
v. 按位异或^
1) 逐位比较两个运算对象生成新值
2) 相异为一,相同为0.
3) 异或与赋值相结合---^=
4) 与1异或即可反转
b. 什么是掩码?(利用&逻辑)
i. 利用与逻辑,让一个n位二进制数,与另一个二进制数相作用,掩码原先为0的位,将被操作数的对应位,
设置成0,这里可以理解为给隐藏了;原先为1的位,被操作数相应位不变。这个n位二进制数就是一个宽
度为n位的掩码
c. 怎么检查位的值?
i. 例如两个值相比较某一位,不可以直接进行比较
ii. 需要将不相干位全部置0或1,也即让待比较的位之外的其他位都一样
d. 按位运算符的优先级小于==
e. 移位运算符
i. 左移<<(左移n位,数值整体乘2的n次幂)
1) (10001010)<<2表示二进制数向左移动2位,左侧末端丢失,右侧末端补0
2) 左移运算不改变值本身
ii. 右移>>(右移n位,数值整体除以2的n次幂)
1) 右移时要分有符号数和无符号数
a) 无符号数:(10010100)>>2表示整体右移2位,右侧丢弃,左侧末尾补0即可(00100101)
b) 有符号数:(10010100)>>2表示整体右移2位,右侧丢弃,左侧末尾补符号位(11100101),也可能
补0,和计算机系统相关
2) 右移运算不改变值本身,而是产生一个新值
iii. 可以利用掩码和移位提取较大单元中的一些位如下图