位运算讲解:
//定义两个8位的变量
unsigned char Byte1 = 0x15;
unsigned char Byte2 = 0xf6;
//一个字节分为8位,叫法不一,都是一个意思
//叫法一:位7 位6 位5 位4 位3 位2 位1 位0
//叫法二:Bit7 Bit6 Bit5 Bit4 Bit3 Bit2 Bit1 Bit0
//叫法三:第8位 第7位 第6位 第5位 第4位 第3位 第2位 第1位
//不建议使用第3种叫法,建议第2种
Byte1 |= (0x01 << 3); //这句的意思:把Byte1的Bit3置1
Byte2 &= ~(0x01 << 6); //这句的意思:把Byte2的Bit6置0
/*1、Byte1 |= (0x01 << 3);的计数过程详解:
1)、|=叫做或等,与+=作用类似,a|=b就是a=a|b,a+=b就是a=a+b。所以Byte1 |= (0x01 << 3);就是Byte1 = Byte1|(0x01 << 3);
2)、0x01用把8位二进制表示:0000 0001 (注:Byte1是8位的数据,所以使用8位二进制,如果Byte1是16位数据,则使用16位二进制...)
然后左移3位,就变成了0000 1000。
3)、Byte1的值是0x15,即0001 0101,Byte1或上(0x01 << 3),就是0001 0101和0000 1000按位或
0001 0101
| 0000 1000
结果是0001 1101,与Byte1的原值相比,区别就是Bit3被置为了1
2、Byte2 &= ~(0x01 << 3);的计数过程详解:
1)、&=叫做与等,a&=b就是a=a&b。所以Byte2 &= ~(0x01 << 3);就是Byte2 = Byte2&(~(0x01 << 3));
2)、0x01用把8位二进制表示:0000 0001
然后左移6位 就变成了 0100 0000
左移后再取反 就变成了 1011 1111
3)、Byte2的值是0xf6,即1111 0110,Byte2与上~(0x01 << 6),就是1111 0110和1011 1111按位与
1111 0110
& 1011 1111
结果是1011 0110,与Byte1的原值相比,区别就是Bit6被置为了0
*/
十六进制数值转换成十进制数值的知识
/*
相关知识:
十六进制数换算成十进制数值的方法
例如:将十六进制数0xAE转换为十进制数
方法一:
转成二进制再换算成十进制二进制:
0xAE的二进制表示: 1 0 1 0 1 1 1 0
各位对应的十进制数值 : 128 64 32 16 8 4 2 1
最终得到十进制数值就是 128 + 32 + 8+4+2 = 174
方法二 :
十六进制直接换算成十进制数值
0xAE:A即10,E即14,进制为16
所以0xAE等于10x16的1次方 + 14x16的0次方 = 174
*/