














类别:想哪写哪 / 日期:2026-03-07 / 浏览:1243 / 评论:0
比如,14的8位原码为00001110。
21的8位原码为00010101。
-21的8位原码为10010101。
比如,14的8位原码、反码、补码都是00001110。
-21的8位反码为11101010。
-21的8位补码为11101011。
计算机内计算要用补码
14+(-21)
00001110+11101011=11111001
得到的结果也是补码,减一是反码
11111000
所以原码是10000111
所以是-7
8位二进制数能表示的十进制数范围为:-128~127
小于-128或大于127,会溢出
0的补码为00000000,-128的补码为10000000
& 按位与运算(双目运算符,自左向右)
| 按位或运算(双目运算符,自左向右)
^ 按位异或(双目运算符,自左向右)
~ 按位取反(单目运算,自右向左)
<< 左移(双目运算符,自左向右)
>> 右移(双目运算符,自左向右)
按位取反优先级最高。
例:正数的补码就是原码本身
char a=3,b=5,c;
c=a&b;
printf("%d\n",c);
00000011
00000101
00000001 补码,正数 就是原码
所以打印出来的是1。负数例子
char a=-3,b=-5,c;
c=a&b;
printf("%d\n",c);
-3原码10000011
反码11111100
补码11111101
-5原码10000101
反码11111010
补码11111011
与运算补码11111001
反码11111000
原码10000111
结果为-7和0做按位与运算,就是清零操作。和1做按位与运算就是保持不变。
比如一个数与0xf(0000 1111)按位与运算得到的结果就是高4位清零,低4位不变。
一个数与00000001做按位与运算,结果得0,那么这个数是偶数。结果是1,这个数是奇数。
例 正数
char a=060,b=017,c;
c=a|b;
printf("%d\n",c);
每3个二进制算一个八进制
060→ 0011 0000
017→ 0000 1111
00111111
正数补码就是原码
所以32+16+8+4+2+1=63负数
char a=060,b=-017,c;
c=a|b;
printf("%d\n",c);
每3个二进制算一个八进制
060→ 0011 0000
-017→ 1000 1111 //原码
11110000 //反码
11110001 //补码
11110001 //得到补码
11110000 //得到返码
10001111 //得到原码
-15char a=5,b;
b=~a;
printf("%d\n",b);
0000 0101
1111 1010 按位取反补码
1111 1001 反码
1000 0110 原码
所以打印出的b的值是-6例1
char a=0xa,b=-0x5,c;
c=a^b;
printf("%d\n",c);
每4个二进制算一个八进制
0xa→ 0000 1010
-0x5→ 1000 0101 //原码
1111 1010 //反码
1111 1011 //补码
0000 1010
1111 0001 //得到补码
1111 0000 //得到返码
1000 1111 //得到原码
-15和0做异或运算,结果不变。和1做异或运算,结果取反。
两个相同的数做异或运算得0。
例2 交换两个整形变量的值
int a=3,b=4; a=a^b; b=b^a; a=a^b;
return:结束当前函数的执行,并可选地返回一个值给调用者。
break:跳出当前所在的循环(for、while、do-while)或 switch 语句,不再执行循环中剩余的语句。
continue:跳过当前循环迭代中剩余的语句,直接开始下一次迭代。
版权声明 : 本文未使用任何知识共享协议授权,您可以任何形式自由转载或使用。
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。