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则是大端

 

目录
打赏
0
0
1
0
23
分享
相关文章
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
在C语言中,内存布局是程序运行时非常重要的概念。内存布局直接影响程序的性能、稳定性和安全性。理解C程序的内存布局,有助于编写更高效和可靠的代码。本文将详细介绍C程序的内存布局,包括代码段、数据段、堆、栈等部分,并提供相关的示例和应用。
78 5
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
121 6
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
93 6
C 语言动态内存分配 —— 灵活掌控内存资源
C语言动态内存分配使程序在运行时灵活管理内存资源,通过malloc、calloc、realloc和free等函数实现内存的申请与释放,提高内存使用效率,适应不同应用场景需求。
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
101 1
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
69 23
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
10 1
一文彻底搞清楚C语言的函数
|
1月前
|
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
75 15
|
1月前
|
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
63 24

热门文章

最新文章