【C语言】数据在内存中的存储(一)

您所在的位置:网站首页 c语言判断数据类型是整数 【C语言】数据在内存中的存储(一)

【C语言】数据在内存中的存储(一)

2023-06-09 12:51| 来源: 网络整理| 查看: 265

数据类型的介绍

内置类型:

char //字符数据类型 short //短整型 int //整型 long //长整型 long long //更长的整型 float //单精度浮点数 double //双精度浮点数

所占空间的大小: image.png 类型的意义:

使用这个类型开辟空间的大小,决定只能使用的范围。 类型的基本归类

整型家族:

char unsigned char signed char short unsigned short [int] signed short [int] int unsigned int signed int long unsigned long signed long

浮点型家族:

float double

构造类型:

int arr[10];//数组类型 int[10]为类型 struct //结构体类型 enum //枚举类型 union //联合类型

指针类型:

int* pi; char* pc; float* pf; void* pv;

空类型: void表示空类型 通常用于函数的返回类型、函数的参数、指针类型。

整型在内存中的存储

变量创建是要在内存开辟空间的,空间的大小是由类型决定的。 变量到底在内存中是怎么存储的呢?一下面的代码为例:

#include int main() { int a = 10; int b = -10; return 0; }

a在内存中的存储b在内存中的存储

原码、反码、补码

计算机中的整数有3种二进制的表现方法,即原码、反码、补码。 3种表现方法都有符号位和数值位两个部分,符号位用0表示正,用1表示负,数值位正数的原码、反码、补码相同。负整数的原码、反码、补码都不相同。 image.png 原码: 直接将数值按照正负数的形式翻译成二进制就可以得到原码。 反码: 将原码的符号位不变,其他的按位取反 补码: 反码+1就得到补码 下图是以-10这个数字为例: image.png 对于整型来说:数据存放在内存中放的是补码 在计算机系统中,数值一律用补码来表示和存储,因为补码可以将符号位和数值域统一进行处理。同时加法和减法可以统一进行处理(CUP只有加法器),补码与原码相互转换,不需要加额外的硬件电路。 一下是我通过计算在存储中的存储 image.png 在编译器内存中的存储如下: image.png 可以看出和我们计算的一样也就是说,内存中存放的是二进制的补码,只不过转化为了16进制。但是我们发现在存放的时候不是按顺序存放的。 这就是大小端存放数据的差异:

大小端介绍 什么是大端小端

大端存储模式,是指数据的低位保存在内存中的高地址中,而数据的高位保存在内存中的低地址中。 小端存储模式,是指数据的高位保存在内存中的高地址中,而数据低位的保存在内存中的低地址中。 下图是大端和小端存储的差异: image.png image.png 由此我们可以得出结论在vs编译器中数据的存储是小端存储。 例题: 请设计一个程序来判断是小端存储还是大端存储

#include int check_sys() { int a = 1; char* p =(char*) &a; if (*p==1) { return 1; } else { return 0; } } int main() { int ret=check_sys(); if (ret==1) { printf("小端\n"); } else { printf("大端\n"); } return 0; }


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3