C语言进阶第一课 -----------深度剖析数据在内存中的存储1

简介: C语言进阶第一课 -----------深度剖析数据在内存中的存储

数据类型介绍

前面我已经介绍了C语言中 常用的数据类型

char         //字符数据类型

short       //短整型

int         //整形

long         //长整型

long long   //更长的整形

float       //单精度浮点数

double       //双精度浮点数

这些数据类型在内存中开辟的大小也在前面介绍过了,可以利用sizeof进行测试

类型的基本归类

整形家族:

char

unsigned char

signed char

short

unsigned short [ int ]

signed short [ int ]

int

unsigned int

signed int

long

unsigned long [ int ]

signed long [ int ]

注意一下,字符在内存存储的是ASCII值,ASCII值是整形,所以char归类为整形类型

我们平时写的

int a;

signed int a;

unsigned  int a;

int a  == signed int a

https://blog.csdn.net/m0_69984273/article/details/131998273  这里简单的介绍过了char,signed char  和unsigned char  C语言没有规定,取决于编译器  

浮点数家族:

float

double

构造类型(自定义):

> 数组类型

> 结构体类型 struct

> 枚举类型 enum

> 联合类型 union

指针类型

int *pi;

char *pc;

float* pf;

void* pv;

空类型:

void 表示空类型(无类型)

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

如:int main(void)

整形在内存中的存储

int a = 20;

int b = 10;

会各自在内存开辟四个字节的空间进行存储

其实计算机能够处理的数据是二进制的,整形和浮点型数据在内存也都是以二进制的形式进行存储。

整数的二进制表示形式有3种:原码、反码、补码

正数的原码、反码、补码相同,

负数的反码是符号位不变,其他位取反, 补码是在反码的基础上加1

#include<stdio.h>
int main()
{
  int a = -10;
  //10000000 00000000 00000000 00001010   原码
  //11111111 11111111 11111111 11110101  反码
  //1111 1111 1111 1111 1111 1111 1111 0110  补码 
  // f    f    f    f    f    f    f    6
  //0xfffffff6
  unsigned int b = -10;// 全部位都是有效位,
  //11111111 11111111 11111111 11110110  补码 
  return 0;
}

4个二进制位表示一个十六进制位

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

为什么呢?

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

一处理;

同时,加法和减法也可以统一处理( CPU 只有加法器 )此外,补码与原码相互转换,其运算过程

是相同的,不需要额外的硬件电路。

假设我们利用原码进行加减   如1 +(-1)

00000000 00000000 00000000 00000001

10000000 00000000 00000000 00000001

这里就会无法确定符号位是否相加

如果使用补码相加

00000000 00000000 00000000 00000001

111111111 111111111 111111111 111111111

不管符号位是否相加都不影响结果

大小端介绍(字节大于等于2的数据)

在内存窗口中就会发现存储的是补码。但是我们发现顺序有点不对劲

大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址

中;

小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位 , ,保存在内存的高地

址中。

例如存储0x11223344

798cd8f8e2bc43cab1f74c23f6aad462.png

四个比特位 表示一个十六进制位, 两个十六进制位表示一个字节

这是因为在计算机系统中,我们是以字节为单位的,每个地址单元

都对应着一个字节,一个字节为8 bit

练习1

设计一个小程序来判断当前机器的字节序

#include <stdio.h>
int check_sys()
{
 int i = 1;
 return (*(char *)&i);
}
int main()
{
 int ret = check_sys();
 if(ret == 1)
 {
 printf("小端\n");
 }
 else
 {
 printf("大端\n");
 }
 return 0;
}
#include <math.h>
int my_end(int a)
{
  int i = 0;
  int sum = 0;
  for (i = 0; i < 8; i++)
  {
    //计算a补码最右端的8位二进制之和
    int b = (a >> i) & 1;
    sum = sum + b * pow(2, i);
  }
  return sum;
}
int main()
{
  int a = 0;
  scanf("%d", &a);
  char* p = (char*)&a;
  //返回*p开始地址指向的那个字节的大小
  int num = my_end(a);
  if (*p = num)
  {
    printf("小端存储");
  }
  else
  {
    printf("大端存储");
  }
  return 0;
}


相关文章
|
1月前
|
存储 程序员 编译器
C 语言中的数据类型转换:连接不同数据世界的桥梁
C语言中的数据类型转换是程序设计中不可或缺的一部分,它如同连接不同数据世界的桥梁,使得不同类型的变量之间能够互相传递和转换,确保了程序的灵活性与兼容性。通过强制类型转换或自动类型转换,C语言允许开发者在保证数据完整性的前提下,实现复杂的数据处理逻辑。
|
1月前
|
存储 编译器 程序员
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
在C语言中,内存布局是程序运行时非常重要的概念。内存布局直接影响程序的性能、稳定性和安全性。理解C程序的内存布局,有助于编写更高效和可靠的代码。本文将详细介绍C程序的内存布局,包括代码段、数据段、堆、栈等部分,并提供相关的示例和应用。
54 5
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
|
1月前
|
存储 数据管理 C语言
C 语言中的文件操作:数据持久化的关键桥梁
C语言中的文件操作是实现数据持久化的重要手段,通过 fopen、fclose、fread、fwrite 等函数,可以实现对文件的创建、读写和关闭,构建程序与外部数据存储之间的桥梁。
|
2月前
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
64 6
|
2月前
|
存储 数据建模 程序员
C 语言结构体 —— 数据封装的利器
C语言结构体是一种用户自定义的数据类型,用于将不同类型的数据组合在一起,形成一个整体。它支持数据封装,便于管理和传递复杂数据,是程序设计中的重要工具。
|
2月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
198 13
|
2月前
|
存储 编译器 数据处理
C 语言结构体与位域:高效数据组织与内存优化
C语言中的结构体与位域是实现高效数据组织和内存优化的重要工具。结构体允许将不同类型的数据组合成一个整体,而位域则进一步允许对结构体成员的位进行精细控制,以节省内存空间。两者结合使用,可在嵌入式系统等资源受限环境中发挥巨大作用。
79 11
|
2月前
|
存储 C语言 开发者
C 语言指针与内存管理
C语言中的指针与内存管理是编程的核心概念。指针用于存储变量的内存地址,实现数据的间接访问和操作;内存管理涉及动态分配(如malloc、free函数)和释放内存,确保程序高效运行并避免内存泄漏。掌握这两者对于编写高质量的C语言程序至关重要。
68 11
|
2月前
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
76 1