数据在内存中的存储方式
1.数据类型的详细介绍
类型决定了开辟空间的大小,同时也决定了使用范围
整型
char
unsigned char 无符号字符型 (范围:0~255,占一个字节)
signed char 有符号字符型(范围:-128~127,占一个字节)
short
unsigned short 无符号短整型(范围:0~65535,占两个字节)
signed short 有符号短整型(范围:-32768~32767,占两个字节)
int
unsigned int 无符号整型(范围:0~4294967295,占四个字节)
signed int 有符号整型(范围:-2147483648~2147483647,占四个字节)
long
unsigned long 无符号长整型(范围:0~2^64-1,占八个字节)
signed long 有符号长整型(范围:-2^31 ~2^31-1,占八个字节)
浮点型
float(占四个字节)
double(占八个字节)
构造类型
数组类型
结构体类型 struct
枚举类型 enum
联合类型 union
指针类型
char*(占四个字节)
int*(占四个字节)
float*(占四个字节)
void*(占四个字节)
虽然他们都占四个字节,但在一般情况下,他们无法互相赋值。
空类型
void表示空类型即无类型。
通常用于函数的返回值类型,函数的参数,指针类型。
void*可以接受任意类型变量的地址,但无法给其他类型指针赋值。
2.整型在内存中的存储(原,反,补)
整型在内存中是以补码的方式存储的。
原因:在计算机系统中,数值一律用补码来表示和存储。原因在于使用补码存储可以将符号位与数据位统一处理,加法减法也能统一处理。此外,补码与原码的相互转换不需要额外的硬件电路。
整型的原码,反码,补码:
对于正数而言:原码=反码=补码;
对于负数而言:
原码:整数的二进制形式。
反码等于原码的符号位不变,其他位按位取反。
补码等于反码+1
例:求-10的原码反码补码
-10
原码:1000 0000 0000 0000 0000 0000 0000 1010
反码:1111 1111 1111 1111 1111 1111 1111 0101 原码符号位不变其他位按位取反而得;
补码:1111 1111 1111 1111 1111 1111 1111 0110 反码+1。
即0X FF FF FF F6,转换为2进制:1111 1111 1111 1111 1111 1111 1111 0110
3.浮点型在内存中的存储
根据国际标准IEEE(电气与电子工程协会)754,任意一个二进制浮点数可以表示成以下的形式
(-1)^S * M * 2^E
(-1)^S 表示符号位,当s=0时为正数,当s=1时为负数。
M表示有效数字,1<M<2;
2^E表示指数位。
对于32位浮点数,最高的一位是符号位S,接着是8个指数位M,最后的23位为有效数字M
对于64位浮点数,最高的一位是符号位S,接着是11个指数位E,最后的52位为有效数字M
示例:
单精度浮点型变量10.125在内存中的存储方式
双精度浮点型变量10.125在内存中的存储方式
10.125的二进制形式为:
1010.001<=>(-1)^0 * 1.010001 * 2^3
由此可得S=0;M=1.010001;在单精度情况下E=127+3;在双精度情况下E=1023+3
单精度浮点数存储为:
0 10000010 10100010000000000000000
转换为16进制为 :0X41 22 00 00
双精度浮点数存储为:
0 10000000010 1010001000000000000000000000000000000000000000000000
转换为16进制为:0X40 24 40 00 00 00 00 00
4.数据在大端和小端中的存储方式
什么是大端小端?
大端(存储模式):指数据的低位保存在内存的高地址中,高位保存在内存的低地址中。
小端(存储模式):指数据的高位保存在内存的高地址中,低位保存在内存的低地址中。
如何判断一台机器是大端存储模式还是小端存储模式?
思路:定义一个所占内存为四个字节的整型变量。利用指向所占内存为一个字节的字符变量指针去读取整型变量的第一个字节,,从而判断存储模式
#include<stdio.h>
int check_system()
{
int i=1;
return (*(char*)&i);
}
int main()
{
int ret=check_system();
if(ret==1)
printf("小端模式\n");
else
printf("大端模式\n");
return 0;
}