⭐️ C语言进阶 ⭐️数据在内存中的存储(深度剖析)(一)

简介: 本文主要讲解点数据类型详细介绍整形在内存中的存储:原码、反码、补码大小端字节序介绍及判断浮点型在内存中的存储解析

前言


本文主要讲解点

  1. 数据类型详细介绍
  2. 整形在内存中的存储:原码、反码、补码
  3. 大小端字节序介绍及判断
  4. 浮点型在内存中的存储解析

数据类型

C语言基本的内置类型

char //字符数据类型
    unsigned char      //signed(有符号)/unsigned(无符号)
    signed char
//大多数编译器默认char为 signed char 即有符号类型(有的认为是unsigned char)
//对于 short int long 都认为是有符号类型
short //短整型
    unsigned short 
    signed short 
int //整形
    unsigned int
    signed int
long //长整型
    unsigned long 
    signed long
long long   //更长的整形
float //单精度浮点数
double //双精度浮点数
//C语言有没有字符串类型?    有字符串,没有字符串类型

型的意义

  1. 使用这个类型开辟内存空间的大小(大小决定了使用范围)
  2. 如何看待内存空间的视角(电脑存取数据看待的视角)

类型的基本归类

  • 整形家族
char
     unsigned char
     signed char
short
     unsigned short [int]
     signed short [int]
int
     unsigned int
     signed int
long
     unsigned long [int]
     signed long [int]
  • 浮点数家族
1. float
2. double
  • 构造类型
> 数组类型
> 结构体类型 struct
> 枚举类型 enum
> 联合类型 union
  • 指针类型
1. int *pi;
2. char *pc;
3. float* pf;
4. void* pv;
  • 空类型
void 表示空类型(无类型)//理论不会开辟空间,要么当做为一个占位符,故不能定义变量
//通常应用于函数的返回类型、函数的参数、指针类型 

整形在内存中的存储


变量的创建会在内存中开辟空间,而空间的大小根据类型来决定

原码、反码、补码

原码、反码和补码三种表示方法均有符号位和数值位

符号位都是用0表示“正”,用1表示“负”(符号位依旧符合二进制运算)

  • 正整数

原、反、补码都相同

  • 负整数

原码:直接将二进制按照正负数的形式翻译成二进制就可以

反码:将原码的符号位不变,其他位依次按位取反就可以得到了

补码:反码+1就得到补码

20210809223548952.png

  • 对于整形来说

数据存放内存中其实放的是补码

而数据的取是使用原码

意义

在计算机系统中,数值一律用补码来表示和存储

使用补码可以将符号位和数值域统一处理

同时加法和减法也可以统一处理(CPU只有加法器)

而补码与原码相互转换的运算过程是相同的(共用一套法则)(不需要额外的硬件电路)

大小端


对于数据在内存存储补码时的字节排列顺序是有差异的(对于不同编译器)

什么是大端小端

大端:指数据的低位保存在内存的高地址中,而数据的高(权)位,保存在内存的低地址中

小端:指数据的低位保存在内存的低地址中,而数据的高(权)位,保存在内存的高地址中

20210810092014401.png


相关文章
|
24天前
|
存储 程序员 编译器
C 语言中的数据类型转换:连接不同数据世界的桥梁
C语言中的数据类型转换是程序设计中不可或缺的一部分,它如同连接不同数据世界的桥梁,使得不同类型的变量之间能够互相传递和转换,确保了程序的灵活性与兼容性。通过强制类型转换或自动类型转换,C语言允许开发者在保证数据完整性的前提下,实现复杂的数据处理逻辑。
|
25天前
|
存储 数据管理 C语言
C 语言中的文件操作:数据持久化的关键桥梁
C语言中的文件操作是实现数据持久化的重要手段,通过 fopen、fclose、fread、fwrite 等函数,可以实现对文件的创建、读写和关闭,构建程序与外部数据存储之间的桥梁。
|
28天前
|
存储 数据建模 程序员
C 语言结构体 —— 数据封装的利器
C语言结构体是一种用户自定义的数据类型,用于将不同类型的数据组合在一起,形成一个整体。它支持数据封装,便于管理和传递复杂数据,是程序设计中的重要工具。
|
1月前
|
存储 编译器 数据处理
C 语言结构体与位域:高效数据组织与内存优化
C语言中的结构体与位域是实现高效数据组织和内存优化的重要工具。结构体允许将不同类型的数据组合成一个整体,而位域则进一步允许对结构体成员的位进行精细控制,以节省内存空间。两者结合使用,可在嵌入式系统等资源受限环境中发挥巨大作用。
62 11
|
2月前
|
存储 C语言
数据在内存中的存储方式
本文介绍了计算机中整数和浮点数的存储方式,包括整数的原码、反码、补码,以及浮点数的IEEE754标准存储格式。同时,探讨了大小端字节序的概念及其判断方法,通过实例代码展示了这些概念的实际应用。
116 1
|
2月前
|
存储
共用体在内存中如何存储数据
共用体(Union)在内存中为所有成员分配同一段内存空间,大小等于最大成员所需的空间。这意味着所有成员共享同一块内存,但同一时间只能存储其中一个成员的数据,无法同时保存多个成员的值。
|
2月前
|
存储 弹性计算 算法
前端大模型应用笔记(四):如何在资源受限例如1核和1G内存的端侧或ECS上运行一个合适的向量存储库及如何优化
本文探讨了在资源受限的嵌入式设备(如1核处理器和1GB内存)上实现高效向量存储和检索的方法,旨在支持端侧大模型应用。文章分析了Annoy、HNSWLib、NMSLib、FLANN、VP-Trees和Lshbox等向量存储库的特点与适用场景,推荐Annoy作为多数情况下的首选方案,并提出了数据预处理、索引优化、查询优化等策略以提升性能。通过这些方法,即使在资源受限的环境中也能实现高效的向量检索。
|
2月前
|
存储 编译器
数据在内存中的存储
数据在内存中的存储
45 4
|
2月前
|
存储 Java
JVM知识体系学习四:排序规范(happens-before原则)、对象创建过程、对象的内存中存储布局、对象的大小、对象头内容、对象如何定位、对象如何分配
这篇文章详细地介绍了Java对象的创建过程、内存布局、对象头的MarkWord、对象的定位方式以及对象的分配策略,并深入探讨了happens-before原则以确保多线程环境下的正确同步。
61 0
JVM知识体系学习四:排序规范(happens-before原则)、对象创建过程、对象的内存中存储布局、对象的大小、对象头内容、对象如何定位、对象如何分配
|
2月前
|
存储 C语言 C++
深入C语言,发现多样的数据之枚举和联合体
深入C语言,发现多样的数据之枚举和联合体
深入C语言,发现多样的数据之枚举和联合体