C语言day06-03原码补码反码

pragma mark 原码补码反码

pragma mark 概念

pragma mark 代码

#include <stdio.h>
int main()
{
    // 其实,数据存储在内存中都是存储的二进制
    // 二进制又可以分为 源码/反码/补码
    // 其实最终存储在内存中的 是“补码”
    
#pragma mark 正数存储的 原码、补码、反码
    /*
     // 9 --> 存储在内存中 --> 二进制
     // 9 是整型 == int == 4个字节 == 1个字节8位 == 整型有32位
     0000 0000 0000 0000 0000 0000 0000 1001 (原码)
     什么是反码 ,正数的反码就是正数的原码
     什么是补码 ,正数的补码就是正数的原码
     总结一句话 : 正数的原码补码反码都是一样的 , 三码合一
     */
    
#pragma mark 负数存储的 原码、补码、反码
    /*
     // -9 --> 存储在内存中 --> 二进制
     其实二进制的第一位是二进制的符号位,如果该位是0代表这个数是一个正数
     1000 0000 0000 0000 0000 0000 0000 1001 (原码)
     反码 : 符号位不变, 其他位取反(0变1 1变0)
     1111 1111 1111 1111 1111 1111 1111 0110 (反码)
     补码 : 反码 + 1 就是补码
     1111 1111 1111 1111 1111 1111 1111 0110 (反码)
    +0000 0000 0000 0000 0000 0000 0000 0001
     1111 1111 1111 1111 1111 1111 1111 0111 (补码)
     */
#pragma mark 练习
    /*
     -15 的原码/ 反码 / 补码
     1000 0000 0000 0000 0000 0000 0000 1111 (原码)
     1111 1111 1111 1111 1111 1111 1111 0000 (反码)
     1111 1111 1111 1111 1111 1111 1111 0001 (补码)
     
     为什么要有原码/补码/反码呢?主要是为了方便计算机计算
     1.由于最高位是符号位,如果是0就代表是整数,如果是1就代表是负数
     2.那么如果直接存储原码,计算机在计算的时候还需要先判断最高位才能计算,效率比较低
     3.为了方便计算机计算,所以有了反码和补码,有了反码和补码之后,以后计算机就不需要判断最高位了,直接计算就可以了
     
     1 + 1
     0001
    +0001
    -------
     0010 == 2
#pragma mark 在原码的思想上做计算 结果是错的
     
     1 - 1 == 1 + (-1) == 计算机只会做加法
     0000 0001  // 原码
    +1000 0001  // 原码
     ----------
     1000 0010 == -2
     
#pragma mark 在反码的思想上做计算
     
     1 - 1 = 1 + (-1)
     0000 0001  // 正1的原码(反码)
     1111 1110  // 负1的反码
     ----------
     1111 1111  == 反码
    将计算出来的反码转换为原码,再将原码转换为十进制
     1000 0000  == 原码 == -0
     
     
#pragma mark 在补码的思想上做计算
     1 - 1 = 1 + (-1)
     0000 0001  // 正1的补码
    +1111 1111  // 负1的补码(是在负1的反码基础上 加上1 变成了补码)
    ---------
    1 0000 0000  == - 0
     
     */
    
    
    return 0;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可...
    yang2yang阅读 2,286评论 1 13
  • 书中关于原码、反码、补码和移码的定义如下(n是机器字长):原码: 反码: 补码: 移码: 原码, 反码, 补码的基...
    困卡阅读 16,111评论 2 8
  • 如果你是一个计算机专业的本科生,那么你可能大一时就在《数字逻辑》(或《数字电路》)这本书里面学习了机器码。可能当时...
    航航大魔王阅读 21,807评论 7 30
  • 机器数之原码反码补码 基本概念 字在计算机中,一串数码作为一个整体来处理或运算的,称为一个计算机字,简称字。字通常...
    Showdy阅读 1,120评论 0 2
  • 这两天看完《NLP改变》,同时执行着30天的分解计划,突然有所感悟: 1、简单才能不平凡。不是我们错误地相信什么或...
    ipea阅读 523评论 1 1