10.原码 反码 补码
生活随笔
收集整理的這篇文章主要介紹了
10.原码 反码 补码
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
+7的原碼:0000 0111?
-7的原碼:1000 0111 ? 第一位0代表正數,1代表負數,第一位為符號位
?
+7的反碼:0000 0111 正數反碼和原碼一樣
-7的反碼:1111 1000 ?符號位不變,其他取反
?
+7的補碼:0000 0111 正數補碼和原碼一樣
-7的補碼:1111 1001 十六進制為:F9 負數的補碼原碼取反再加一
?
舉個例子:
1 #include<stdio.h> 2 #include<stdlib.h> 3 4 void main() 5 { 6 char ch = -17; 7 //0001 0001 +17原碼 8 //1001 0001 -17原碼 9 //1110 1110 反碼 10 //1110 1111 -17補碼 十六進制:ef 11 printf("%p", &ch); 12 13 getchar(); 14 15 }查看內存變量: ?
規律:
正數:原碼,反碼,補碼,正數都是一樣的
負數:原碼取反(不包括符號位)+1 = 補碼
1 #include<stdio.h> 2 #include<stdlib.h> 3 4 void main() 5 { 6 int num = -1; 7 //0000 0000 0000 0000 0000 0000 0000 0001 +1原碼 8 //1000 0000 0000 0000 0000 0000 0000 0001 -1原碼 9 //1111 1111 1111 1111 1111 1111 1111 1110 -1反碼 10 //1111 1111 1111 1111 1111 1111 1111 1111 -1補碼 11 printf("%u", num); 12 13 getchar();
結果:
補碼的好處:
+7補碼:0000 0111 ?補碼為:0000 0111
-1補碼:1000 0001 ? 補碼為: 1111 1111
? 補碼和為: 0000 0110 換成原碼就是+6 ? ? ? ? ? ?
?
+7補碼:0000 0111?
-9補碼: ?1111 0111
和為: ? ? ?1111 ?1110
反碼為: ? 1000 0001?
再加1 : ? ?1000 0010 代表的數為-2
?
轉載于:https://www.cnblogs.com/xiaochi/p/8094196.html
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的10.原码 反码 补码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JVM——虚拟机的简介【摘录】
- 下一篇: USACO Broken Necklac