1. & 按位与
1> 功能
只有对应的两个二进位均为1时,结果位才为1,否则为0。
2> 举例: 比如9&5,其实就是1001&101=1,因此9&5=1
3> 规律
二进制中,与1相&就保持原位,与0相&就为0
2. | 按位或
1> 功能
只要对应的二个二进位有一个为1时,结果位就为1,否则为0。
2> 举例: 比如9|5,其实就是1001|101=1101,因此9|5=13
3. ^ 按位异或
1> 功能
当对应的二进位相异(不相同)时,结果为1,否则为0。
2> 举例: 比如9^5,其实就是1001^101=1100,因此9^5=12
3> 规律
相同整数相^的结果是0。比如5^5=0
多个整数相^的结果跟顺序无关。比如5^6^7=5^7^6
因此得出结论:a^b^a = b
4. ~ 取反
对整数a的各二进位进行取反,符号位也取反(0变1,1变0)
5. << 左移
把整数a的各二进位全部左移n位,高位丢弃,低位补0。左移n位其实就是乘以2的n次方
由于左移是丢弃最高位,0补最低位,所以符号位也会被丢弃,左移出来的结果值可能会改变正负性
6. >> 右移
把整数a的各二进位全部右移n位,保持符号位不变。右移n位其实就是除以2的n次方
为正数时, 符号位为0,最高位补0
为负数时,符号位为1,最高位是补0或是补1 取决于编译系统的规定
7.学习代码
1 #include
2
3
4 int main()
5 {
6 /* 按位与 &
7
8 10101010000
9 00000100000
10 -------------
11 00000000000
12
13 10111011
14 10101101
15 ---------
16 10101001
17
18 1001
19 0101
20 -----
21 0001
22 */
23
24 /*
25 按位或 |
26 1001
27 0101
28 -----
29 1101
30 */
31
32
33 /*
34 按位异或 ^
35 1.相同数值进行异或,结果肯定是0,比如9^9
36 2.交换 9^5^6 == 9^6^5
37 3.任何数值跟0进行异或,结果还是原来的数值,9^0 == 9
38 4.a^b^a == a^a^b == 0^b == b
39
40 1001
41 0101
42 -----
43 1100
44
45 1001
46 1001
47 -----
48 00000
49
50 0101
51 0000
52 ----
53 0101
54
55 9^5^9 == 9^9^5 = 0^5 = 5
56
57 a^b^a == b
58 */
59 //printf("%d\n", 9^9);
60
61 //printf("%d\n", 9 ^ 5);
62
63 /*
64 按位取反 ~
65 ~0000 0000 0000 0000 0000 0000 0000 1001
66 1111 1111 1111 1111 1111 1111 1111 0110
67 */
68 //printf("%d\n", ~9);
69
70 /*
71 左移 <<
72
73 0000 0000 0000 0000 0000 0000 0000 0000
74 00 0000 0000 0000 0000 0000 0000 100100
75
76 9<<1 -> 9 * 2的1次方 == 18
77 9<<2 -> 9 * 2的2次方 ==36
78 9< 9 * 2的n次方
79 */
80
81 //printf("%d\n", 9<<1);
82
83 /*
84 右移 >>
85 0000 0000 0000 0000 0000 0000 0000 0000
86 000000 0000 0000 0000 0000 0000 0000 10
87 111111 1111 1111 1111 1111 1111 1111 10
88
89 8>>1 -> 8/2 == 4
90 8>>2 -> 8/2的2次方 == 2
91 8>>n -> 8/2的n次方
92 */
93
94 printf("%d\n", 8>>3);
95
96 return 0;
97 }
1 #include
2
3 /*
4 使用位异或运算符交换两个变量的值
5 */
6
7 int main()
8 {
9 int a = 10;
10 int b = 11;
11
12 /* 借助第三方变量
13 int temp = a;
14 a = b;
15 b = temp;
16 */
17
18 /*
19 a = b - a;
20 b = b - a;
21 a = b + a;
22 */
23
24 // a^b^a == b
25
26 // a --> 10^11
27 // b --> 10
28 a = a ^ b;
29 b = a ^ b;
30 a = a ^ b;
31
32 printf("a=%d, b=%d\n", a, b);
33
34 return 0;
35 }
1 #include
2 /*
3 用位与&运算符判断变量的奇偶性
4 */
5 int main()
6 {
7 /*
8 15: 1111
9 9: 1001
10
11 14: 1110
12 10: 1010
13 */
14 int a = 15;
15
16 a&1 == 1 // 奇数
17 a&1 == 0 // 偶数
18
19 /*
20 if (a%2) {
21 printf("奇数\n");
22 } else {
23 printf("偶数\n");
24 }*/
25
26 //a%2==0?printf("偶数\n"):printf("奇数\n");
27
28 //a%2?printf("奇数\n"):printf("偶数\n");
29
30
31
32 return 0;
33 }
1 /*
2 写一个函数,用来输出整数在内存中的二进制形式
3 */
4
5 #include
6 void printBinary(int number);
7
8 int main()
9 {
10 /*
11 0000 0000 0000 0000 0000 0000 0000 0000
12 0000 0000 0000 0000 0000 0000 0000 1111
13
14 9 : 0000 0000 0000 0000 0000 0000 0000 1001
15 -10 : 1111 1111 1111 1111 1111 1111 1111 0110
16 */
17
18
19 //printf("%d\n", ~9);
20
21
22 printBinary(-10);
23 return 0;
24 }
25
26 void printBinary(int number)
27 {
28
29 // 记录现在挪到第几位
30 // (sizeof(number)*8) - 1 == 31
31 int temp = ( sizeof(number)<<3 ) - 1;
32
33 while ( temp >= 0 )
34 {
35 // 先挪位,再&1,取出对应位的值
36 int value = (number>>temp) & 1;
37 printf("%d", value);
38
39 //
40 temp--;
41
42 // 每输出4位,就输出一个空格
43 if ( (temp + 1) % 4 == 0 )
44 {
45 printf(" ");
46 }
47 }
48
49 printf("\n");
50 }
时间: 06-18