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

 

相关文章
|
29天前
|
存储 编译器 程序员
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
在C语言中,内存布局是程序运行时非常重要的概念。内存布局直接影响程序的性能、稳定性和安全性。理解C程序的内存布局,有助于编写更高效和可靠的代码。本文将详细介绍C程序的内存布局,包括代码段、数据段、堆、栈等部分,并提供相关的示例和应用。
43 5
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
|
29天前
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
59 6
|
1月前
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
51 6
|
1月前
|
大数据 C语言
C 语言动态内存分配 —— 灵活掌控内存资源
C语言动态内存分配使程序在运行时灵活管理内存资源,通过malloc、calloc、realloc和free等函数实现内存的申请与释放,提高内存使用效率,适应不同应用场景需求。
|
1月前
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
1月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
63 1
|
1月前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
322 1
|
26天前
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
1月前
|
Java
JVM内存参数
-Xmx[]:堆空间最大内存 -Xms[]:堆空间最小内存,一般设置成跟堆空间最大内存一样的 -Xmn[]:新生代的最大内存 -xx[use 垃圾回收器名称]:指定垃圾回收器 -xss:设置单个线程栈大小 一般设堆空间为最大可用物理地址的百分之80
|
1月前
|
Java
JVM运行时数据区(内存结构)
1)虚拟机栈:每次调用方法都会在虚拟机栈中产生一个栈帧,每个栈帧中都有方法的参数、局部变量、方法出口等信息,方法执行完毕后释放栈帧 (2)本地方法栈:为native修饰的本地方法提供的空间,在HotSpot中与虚拟机合二为一 (3)程序计数器:保存指令执行的地址,方便线程切回后能继续执行代码
22 3