⭐️ 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


相关文章
|
20天前
|
消息中间件 存储 缓存
kafka 的数据是放在磁盘上还是内存上,为什么速度会快?
Kafka的数据存储机制通过将数据同时写入磁盘和内存,确保高吞吐量与持久性。其日志文件按主题和分区组织,使用预写日志(WAL)保证数据持久性,并借助操作系统的页缓存加速读取。Kafka采用顺序I/O、零拷贝技术和批量处理优化性能,支持分区分段以实现并行处理。示例代码展示了如何使用KafkaProducer发送消息。
|
2月前
|
存储 编译器 程序员
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
在C语言中,内存布局是程序运行时非常重要的概念。内存布局直接影响程序的性能、稳定性和安全性。理解C程序的内存布局,有助于编写更高效和可靠的代码。本文将详细介绍C程序的内存布局,包括代码段、数据段、堆、栈等部分,并提供相关的示例和应用。
74 5
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
|
2月前
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
102 6
|
3月前
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
88 6
|
3月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
267 13
|
3月前
|
大数据 C语言
C 语言动态内存分配 —— 灵活掌控内存资源
C语言动态内存分配使程序在运行时灵活管理内存资源,通过malloc、calloc、realloc和free等函数实现内存的申请与释放,提高内存使用效率,适应不同应用场景需求。
|
3月前
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
3月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
99 1
|
3月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
3月前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
635 1

热门文章

最新文章