深剖整形在内存中是怎么存储的-C语言

简介: 深剖整形在内存中是怎么存储的-C语言

整形在内存中的存储

整形在内存中以补码形式存储
复制代码


原因:

在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,
可以将符号位和数值域统一处理; 
同时,加法和减法也可以统一处理(CPU只有加法器)此外,补码与原码相互转换,
其运算过程是相同的,不需要额外的硬件电路
复制代码

1 + (-1)
假设使用原码计算:
1的原码:  00000000 00000000 00000000 00000001
-1的原码: 10000000 00000000 00000000 00000001
    -----------------------------------------
         10000000 00000000 00000000 00000010 ->-2
   所以1+(-1) -2 //err
复制代码

1 + (-1)
   假设使用补码计算
1的原码:00000000 00000000 00000000 00000001 
1的补码:00000000 00000000 00000000 00000001 
   正数原反补相同
-1的原码:10000000 00000000 00000000 00000001 
    反码:11111111 11111111 11111111 11111110
    补码:11111111 11111111 11111111 11111111
  两个补码运算
      00000000 00000000 00000000 00000001 
    + 11111111 11111111 11111111 11111111
   -----------------------------------------
   1  00000000 00000000 00000000 00000000    
      计算出进位,有33位,但是只取32位->结果为0
复制代码


原码反码补码

image.png


已知补码求原码:

方法1:对补码A求补码B求出的补码B就是补码A的原码

方法2:

补码-1 ->反码

反码按位取反(符号位不变)->得到原码



例:
   已知补码:11111111 11111111 11111111 11111111 求原码
      11111111 11111111 11111111 11111111
 方法1:对补码再求补码,把要求的补码当成原码,求出来的补码就是原码
       11111111 11111111 11111111 11111111-原码
       10000000 00000000 00000000 00000000-反码
       10000000 00000000 00000000 00000001-补码
    得出的该补码10000000 00000000 00000000 00000001,就是要求的11111111 11111111 11111111 11111111补码的原码->值为-1
复制代码
方法2:
   补码 - 1   -> 反码
  11111111 11111111 11111111 11111110 ->反码
    反码按位取反(符号位不变) ->原码
  10000000 00000000 00000000 00000001 ->原码
    该原码的值为-1
复制代码


相关文章
|
6天前
|
存储
数据在内存中的存储之整数存储
数据在内存中的存储之整数存储
14 0
|
7天前
|
C语言
C语言:内存函数(memcpy memmove memset memcmp使用)
C语言:内存函数(memcpy memmove memset memcmp使用)
|
2天前
|
存储 C语言 开发者
【C言专栏】C 语言实现动态内存分配
【4月更文挑战第30天】C语言中的动态内存分配允许程序运行时按需分配内存,提供处理未知数据量的灵活性。这涉及`malloc()`, `calloc()`, `realloc()`, 和 `free()`四个标准库函数。`malloc()`分配指定大小的内存,`calloc()`同时初始化为零,`realloc()`调整内存大小,而`free()`释放内存。开发者需谨慎处理内存泄漏和指针使用,确保程序的稳定性和性能。动态内存分配是C语言中的重要技能,但也需要良好的内存管理实践。
|
2天前
|
存储 程序员 C语言
C语言进阶第九课 --------动态内存管理-2
C语言进阶第九课 --------动态内存管理
|
2天前
|
编译器 C语言
C语言进阶第九课 --------动态内存管理-1
C语言进阶第九课 --------动态内存管理
|
6天前
|
存储 算法
【三种方法】求一个整数存储在内存中二进制中的1的个数附两道课外练习题
【三种方法】求一个整数存储在内存中二进制中的1的个数附两道课外练习题
7 0
|
7天前
|
程序员 编译器 C语言
C语言知识:动态内存管理(malloc free calloc realloc)
C语言知识:动态内存管理(malloc free calloc realloc)
|
7天前
|
存储 编译器 C语言
C语言基础知识:数据在内存中的存储解析(整数,浮点数)
C语言基础知识:数据在内存中的存储解析(整数,浮点数)
|
9天前
|
存储 C语言
C语言动态存储方式与静态存储方式
C语言动态存储方式与静态存储方式
7 0
|
6天前
|
Linux
Linux rsyslog占用内存CPU过高解决办法
该文档描述了`rsyslog`占用内存过高的问题及其解决方案。
29 4