【C语言】 数据的存储 -- 数据类型介绍 -- 存储 -- 浮点型在内存中的存储,很详细也很重要,不明白的一定要看1

简介: 【C语言】 数据的存储 -- 数据类型介绍 -- 存储 -- 浮点型在内存中的存储,很详细也很重要,不明白的一定要看1

*************************************************正文开始*************************************************

1、数据类型介绍

前面我们已经学习了基本的内置类型(C语言已经有的类型叫做内置类型)
char         short         int         long         long long         float         double

以及他们所占存储空间的大小。

类型的意义:

       1.使用这个类型开辟内存空间的大小(大小决定了适用范围)。

       2.如何看待内存空间的视角。

1.1 类型的基本归类

整型家族:

char
  unsigned char
  signed char//char = signed char 是取决于编译器的
short
  unsigned short [int]//这里的int可以不写,下面一致 
  signed short[int]//short = signed short ,signed 可省略
int 
  unsigned int 
  signed int //int = signed int ,signed 可省略
long
  unsigned long [int]
  signed long [int]//long = signed long ,signed 可省略

注:


1.字符存储和表示的时候本质上使用的是ASCII码值,ASCII码值是整数,因此字符类型也归类到整型家族;


2.数值在分类的时候有正有负,因次就存在 unsigned(无符号,只有正),signed (有符号,可正可负),平时写的 int = signed int,signed可省略 。但是 char == signed char 是取决于编译器的(见到的编译器上大多是等于的)。


浮点型家族:

float
double

构造类型(自定义类型):

>数组类型  //int arr[5],char str[10]
>结构体类型 struct
>枚举类型 enum
>联合类型 union

指针类型:

int *pi;//+-1跳过几个字节看指针的类型,解引用访问几个字节也是看指针类型
char *pc;
float *pf;
void *pv;

空类型:

void 表示空类型(无类型)

通常应用于函数的返回类型、函数的参数、指针类型。

函数不希望有任何返回值就用 void ;函数的参数写成 void 代表了这个函数不需要参数;void* p 是无具体类型的指针。

2、整型在内存中的存储

一个变量的创建是要在内存中开辟空间的。空间的大小是根据不同的类型而决定的。

那接下来我们他谈数据在所开辟的内存中到底是如何存储的?

比如:

int a = 20;
int b = -10;

我们知道为 a 分配四个字节的空间。

那如何存储?

下来了解下面的概念:

2.1 原码、反码、补码

计算机中的整数有三种2进制的表示方法,即原码、反码、补码。

三种表示方法均有符号位和数值位两部分,符号位都是用‘0’表示“正“,用‘1’表示”负“,而数值位只要把这个数字表示清楚就可以。
正数的原、反、补码都相同。

负整数的三种表示方法各不相同。

举例:

int main()
{
  int a = 20;
  //原码:00000000 00000000 00000000 00010100
  //反码:00000000 00000000 00000000 00010100
  //补码:00000000 00000000 00000000 00010100
  int b = -10;
  //原码:10000000 00000000 00000000 00001010
  //反码:11111111 11111111 11111111 11110101
  //补码:11111111 11111111 11111111 11110110
  return 0;
}


原码


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


反码


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


补码


反码+1就得到补码。


对于整型来说:数据存放内存中其实存放的是补码。


我们为了更加清楚,使用调试可以观察一下内存中如何存储:


正数的原反补码相同说明不了问题,我们来看负数的


这里是为了方便展示所以用的 16进制,在内存中就是以 2进制存储的。2进制数转换为 16进制数就是 ff ff ff f6。


Q:为什么数据存放内存中其实存放的是补码呢?


A:在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一处理;


同时,加法和减法也可以统一处理(CPU只有加法器)此外,补码与原码相互交换,其运算过程是相同的,不需要额外的硬件电路。


这段话有点难理解,我们举例来说明一下:


我们以 1 - 1 来说。上面的话说 CPU 只有加法器,而我们这里却是用减法处理的,因此我们改写为 1+(-1),而CPU就是这样来做的。

int main()
{
  1 + 1;
  1 + (-1);
  //1的补码: 00000000 00000000 00000000 00000001
  //-1的原码:10000000 00000000 00000000 00000001
  //-1的反码:11111111 11111111 11111111 11111110
  //-1的补码:11111111 11111111 11111111 11111111
  //1+(-1)补码相加:1 00000000 00000000 00000000 00000000
  return 0;
}

分析:



这也说明了内存中存储的是补码。

相关文章
|
5月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
324 15
|
存储 程序员 编译器
C 语言中的数据类型转换:连接不同数据世界的桥梁
C语言中的数据类型转换是程序设计中不可或缺的一部分,它如同连接不同数据世界的桥梁,使得不同类型的变量之间能够互相传递和转换,确保了程序的灵活性与兼容性。通过强制类型转换或自动类型转换,C语言允许开发者在保证数据完整性的前提下,实现复杂的数据处理逻辑。
|
11月前
|
消息中间件 存储 缓存
kafka 的数据是放在磁盘上还是内存上,为什么速度会快?
Kafka的数据存储机制通过将数据同时写入磁盘和内存,确保高吞吐量与持久性。其日志文件按主题和分区组织,使用预写日志(WAL)保证数据持久性,并借助操作系统的页缓存加速读取。Kafka采用顺序I/O、零拷贝技术和批量处理优化性能,支持分区分段以实现并行处理。示例代码展示了如何使用KafkaProducer发送消息。
|
存储 编译器 程序员
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
在C语言中,内存布局是程序运行时非常重要的概念。内存布局直接影响程序的性能、稳定性和安全性。理解C程序的内存布局,有助于编写更高效和可靠的代码。本文将详细介绍C程序的内存布局,包括代码段、数据段、堆、栈等部分,并提供相关的示例和应用。
420 5
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
|
存储 数据管理 C语言
C 语言中的文件操作:数据持久化的关键桥梁
C语言中的文件操作是实现数据持久化的重要手段,通过 fopen、fclose、fread、fwrite 等函数,可以实现对文件的创建、读写和关闭,构建程序与外部数据存储之间的桥梁。
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
413 6
|
存储 数据建模 程序员
C 语言结构体 —— 数据封装的利器
C语言结构体是一种用户自定义的数据类型,用于将不同类型的数据组合在一起,形成一个整体。它支持数据封装,便于管理和传递复杂数据,是程序设计中的重要工具。
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
319 6
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
431 1