C语言 “整型在内存的存储,大小端存储模式的介绍“

简介: C语言 “整型在内存的存储,大小端存储模式的介绍“

一、数据类型介绍

1、C语言当中的数据类型以及字节大小

2、类型的基本归类

       (1)整型家族:

                       

       (2)浮点型家族:

                       

       (3)构造类型:

                       

       (4)指针类型:

                       

       (5)void空类型:通常用于函数的返回类型,函数的参数,指针类型。


二、整型在内存中的存储方式

我们知道整型在内存中被分配了4个字节

创建两个整型变量a,b:

                               

我们可以用调试的方式看它的内存存储方式

a的值是10,在内存中存储的形式如上图0a 00 00 00,而vs为了方便观察,展示出来的是16进制的数字,a就是10,很好的给我们反馈出来了,而他把字节序小的位数放在了低地址处,这其实就是小端字节的排序方式

在讲负数在内存中的存储方式之前我们先介绍原码,反码,补码

       原码,反码,补码:

       正数的原码,反码,补码相同。(整型的二进制)

       负数的原码,反码,补码的关系:

               原码:把10进制或其他进制的数转换成2进制

               反码:原码除符号位(第一位)不变,其他全部按位取反

               补码:反码加一

(补充:补码转换成原码可以先减一再按位取反,也可以先按位取反再加一,和原码转换成补码一样。

所有整数在内存中存储是以补码的形式存储的。

-10在内存的存储形式是f6 ff ff ff

我们可以使用计算机算出-1016进制

可以看到,和上面内存中存储的16进制相同

如果我们想计算出a+b的值呢,如果直接用a和b的原码计算,是计算不出来的,因为b是负数,负数的符号位是1,其实计算机的cpu只有加法运算,没有减法,要进行负数的运算,就得将其转化成补码,在将两个的补码转换成原码算出来

我们先将-10的原码,反码,补码写出来

原码:1111111111111111111111111111111111111111111111111111111111110110

反码:10000000000000000000000000000000000000000000000000001001

补码:10000000000000000000000000000000000000000000000000001010

a+b的补码计算过程

       a:00000000000000000000000000000000000000000000000000001010

       b:10000000000000000000000000000000000000000000000000001010

  a+b:100000000000000000000000000000000000000000000000000000000

再往二进制级次低位那个方向取32个比特位,去掉1,就是32个0,a+b的结果也就是0。


三、大小端存储模式的介绍及判断

       (1)介绍

       小端存储模式:指数据中字节位序小的数存储到低地址处,字节位序大的数存储到高地址处。

       大端存储模式:指数据中字节位序大的数存储到低地址处,字节位序小的数存储到搞地址处。

       (2)判断VS中内存的存储模式是大端还是小段,写一段代码,进行判断

       地址是由低到高的,我们令a = 500可以看到内存的存储方式是这样的,

       

500的十六进制是1f4

这里数据中的低字节位放在了低地址处

所以,在VS中内存的存储方式是小端存储方式。

(3)设计判断大小端字节序的代码:

原理:令一个整型变量i = 1,他在内存中存储方式有两种,也就是大端或小段

上面是小端

下面是大端

我们i是能访问4个字节的,就需要把他强制转换成char类型,让其访问1个字节,再对其解引用,若是1则是小端0则是大端

 

相关文章
|
2月前
|
存储 编译器 C语言
C语言存储类详解
在 C 语言中,存储类定义了变量的生命周期、作用域和可见性。主要包括:`auto`(默认存储类,块级作用域),`register`(建议存储在寄存器中,作用域同 `auto`,不可取地址),`static`(生命周期贯穿整个程序,局部静态变量在函数间保持值,全局静态变量限于本文件),`extern`(声明变量在其他文件中定义,允许跨文件访问)。此外,`typedef` 用于定义新数据类型名称,提升代码可读性。 示例代码展示了不同存储类变量的使用方式,通过两次调用 `function()` 函数,观察静态变量 `b` 的变化。合理选择存储类可以优化程序性能和内存使用。
156 82
|
22天前
|
缓存 算法 数据处理
如何选择合适的内存访问模式
【10月更文挑战第20天】如何选择合适的内存访问模式
38 1
|
1月前
|
存储 程序员 编译器
C语言——动态内存管理与内存操作函数
C语言——动态内存管理与内存操作函数
|
22天前
|
存储 C语言
【c语言】字符串函数和内存函数
本文介绍了C语言中常用的字符串函数和内存函数,包括`strlen`、`strcpy`、`strcat`、`strcmp`、`strstr`、`strncpy`、`strncat`、`strncmp`、`strtok`、`memcpy`、`memmove`和`memset`等函数的使用方法及模拟实现。文章详细讲解了每个函数的功能、参数、返回值,并提供了具体的代码示例,帮助读者更好地理解和掌握这些函数的应用。
19 0
|
1月前
|
存储 C语言
深入C语言内存:数据在内存中的存储
深入C语言内存:数据在内存中的存储
|
2月前
|
存储 人工智能 C语言
数据结构基础详解(C语言): 栈的括号匹配(实战)与栈的表达式求值&&特殊矩阵的压缩存储
本文首先介绍了栈的应用之一——括号匹配,利用栈的特性实现左右括号的匹配检测。接着详细描述了南京理工大学的一道编程题,要求判断输入字符串中的括号是否正确匹配,并给出了完整的代码示例。此外,还探讨了栈在表达式求值中的应用,包括中缀、后缀和前缀表达式的转换与计算方法。最后,文章介绍了矩阵的压缩存储技术,涵盖对称矩阵、三角矩阵及稀疏矩阵的不同压缩存储策略,提高存储效率。
383 8
|
1月前
|
存储 C语言
C语言中的浮点数存储:深入探讨
C语言中的浮点数存储:深入探讨
|
1月前
|
存储
整型在内存中的存储
本文详细解释了计算机中整型数据的三种二进制表示方法:原码、反码和补码,并展示了如何将正数和负数的原码转换为反码和补码。
38 0
|
1月前
|
编译器 C语言 C++
【C语言】精妙运用内存函数:深入底层逻辑的探索
【C语言】精妙运用内存函数:深入底层逻辑的探索
|
3月前
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
366 0