惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

博客园 - 叶小钗
云风的 BLOG
云风的 BLOG
G
Google Developers Blog
S
SegmentFault 最新的问题
罗磊的独立博客
Hugging Face - Blog
Hugging Face - Blog
美团技术团队
爱范儿
爱范儿
博客园 - 三生石上(FineUI控件)
H
Hackread – Cybersecurity News, Data Breaches, AI and More
D
DataBreaches.Net
F
Fortinet All Blogs
TaoSecurity Blog
TaoSecurity Blog
D
Docker
C
Cybersecurity and Infrastructure Security Agency CISA
K
Kaspersky official blog
宝玉的分享
宝玉的分享
腾讯CDC
Google Online Security Blog
Google Online Security Blog
Recorded Future
Recorded Future
T
The Exploit Database - CXSecurity.com
T
The Blog of Author Tim Ferriss
V
V2EX
S
Securelist
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
C
CERT Recently Published Vulnerability Notes
A
Arctic Wolf
Scott Helme
Scott Helme
L
LINUX DO - 热门话题
Y
Y Combinator Blog
P
Proofpoint News Feed
T
Tor Project blog
AWS News Blog
AWS News Blog
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
The Last Watchdog
The Last Watchdog
博客园 - 聂微东
T
Threat Research - Cisco Blogs
B
Blog
Attack and Defense Labs
Attack and Defense Labs
L
Lohrmann on Cybersecurity
C
CXSECURITY Database RSS Feed - CXSecurity.com
阮一峰的网络日志
阮一峰的网络日志
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
IT之家
IT之家
N
News and Events Feed by Topic
博客园 - 司徒正美
H
Help Net Security
C
Cisco Blogs
C
Check Point Blog
S
Secure Thoughts

飘雪博客

今年太惨了 - 工作记录 - 飘雪博客 房屋维修基金 - 想哪写哪 - 飘雪博客 民生银行离谱 - 想哪写哪 - 飘雪博客 遭遇催收轰炸 - 想哪写哪 - 飘雪博客 摸鱼网站-1 老男人游戏网关了 /(ㄒoㄒ)/~~ - 想哪写哪 经过我苦口婆心的劝说,孩子愿意报足球了 - 想哪写哪 - 飘雪博客 c语言不懂的知识点2——链表 - 想哪写哪 - 飘雪博客 孩子近视了! - 想哪写哪 - 飘雪博客 给博客增加了留言邮件通知插件以及草稿箱 - 想哪写哪 - 飘雪博客 备忘:小智固件 - 想哪写哪 - 飘雪博客
c语言中学不会的知识点 - 想哪写哪 - 飘雪博客
2026-03-07 · via 飘雪博客

类别:想哪写哪 / 日期:2026-03-07 / 浏览:1243 / 评论:0

原码反码补码

原码:二进制的首位为标志位,0为正数,1为负数。

比如,14的8位原码为00001110。

 21的8位原码00010101。

-21的8位原码10010101。

反码:正数的原码反码补码相同,都是原码本身。负数的反码是符号位不变,其他位取反。

比如,14的8位原码、反码、补码都是00001110。

-21的8位反码为11101010。

补码:正数的补码还是原码。负数的补码是反码+1。

-21的8位补码为11101011。

计算

计算机内计算要用补码

14+(-21)

00001110+11101011=11111001

得到的结果也是补码,减一是反码

11111000

所以原码是10000111

所以是-7

总结

8位二进制数能表示的十进制数范围为:-128~127

小于-128或大于127,会溢出

0的补码为00000000,-128的补码为10000000

位运算(用补码运算)

& 按位与运算(双目运算符,自左向右)

| 按位或运算(双目运算符,自左向右)

^ 按位异或(双目运算符,自左向右)

~ 按位取反(单目运算,自右向左)

<< 左移(双目运算符,自左向右)

>> 右移(双目运算符,自左向右)

按位取反优先级最高。

按位与运算,只要有0参与,结果都是0。

例:正数的补码就是原码本身

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,这个数是奇数。

按位或运算,只要有1参与的,结果都是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  //得到原码 
-15

和1做按位或运算,置1操作。和0做按位或运算就是保持不变。

按位取反——所有位都要取反,包括符号位

char a=5,b;
b=~a;
printf("%d\n",b);
0000 0101
1111 1010 按位取反补码
1111 1001 反码
1000 0110 原码
所以打印出的b的值是-6

按位异或——相同得0,不同得1

例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 continue区别

return:结束当前函数的执行,并可选地返回一个值给调用者。

break:跳出当前所在的循环(for、while、do-while)或 switch 语句,不再执行循环中剩余的语句。

continue:跳过当前循环迭代中剩余的语句,直接开始下一次迭代。

版权声明 : 本文未使用任何知识共享协议授权,您可以任何形式自由转载或使用。