您现在的位置是:首页 >学无止境 >【C语言】数据在内存中的存储(一)网站首页学无止境
【C语言】数据在内存中的存储(一)
简介【C语言】数据在内存中的存储(一)
数据类型的介绍
内置类型:
char //字符数据类型
short //短整型
int //整型
long //长整型
long long //更长的整型
float //单精度浮点数
double //双精度浮点数
所占空间的大小:
类型的意义:
- 使用这个类型开辟空间的大小,决定只能使用的范围。
类型的基本归类
整型家族:
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<stdio.h>
int main()
{
int a = 10;
int b = -10;
return 0;
}
原码、反码、补码
计算机中的整数有3种二进制的表现方法,即原码、反码、补码。
3种表现方法都有符号位和数值位两个部分,符号位用0表示正,用1表示负,数值位正数的原码、反码、补码相同。负整数的原码、反码、补码都不相同。
原码:
直接将数值按照正负数的形式翻译成二进制就可以得到原码。
反码:
将原码的符号位不变,其他的按位取反
补码:
反码+1就得到补码
下图是以-10这个数字为例:
对于整型来说:数据存放在内存中放的是补码
在计算机系统中,数值一律用补码来表示和存储,因为补码可以将符号位和数值域统一进行处理。同时加法和减法可以统一进行处理(CUP只有加法器),补码与原码相互转换,不需要加额外的硬件电路。
一下是我通过计算在存储中的存储
在编译器内存中的存储如下:
可以看出和我们计算的一样也就是说,内存中存放的是二进制的补码,只不过转化为了16进制。但是我们发现在存放的时候不是按顺序存放的。
这就是大小端存放数据的差异:
大小端介绍
什么是大端小端
大端存储模式,是指数据的低位保存在内存中的高地址中,而数据的高位保存在内存中的低地址中。
小端存储模式,是指数据的高位保存在内存中的高地址中,而数据低位的保存在内存中的低地址中。
下图是大端和小端存储的差异:
由此我们可以得出结论在vs编译器中数据的存储是小端存储。
例题:
请设计一个程序来判断是小端存储还是大端存储
#include<stdio.h>
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("小端
");
}
else
{
printf("大端
");
}
return 0;
}
风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。