uint8 int8

signed char int8;
unsigned char uint8;

int int16;
unsigned int uint16;

long int32;
unsigned long uint32;

long long int64;
unsigned long long uint64;

在这里插入图片描述

编译器不同,宽度是不相同,分别如下:

//—64位编译器—//

char :1个字节
char*(即指针变量): 8个字节
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 4个字节
long long: 8个字节
unsigned long: 8个字节
_int64:8个字节

所以,对于64位编译器来说,各种类型的范围如下:

unsigned int:0~4294967295(0~2^32-1) 
int:-2147483648~2147483647(-2^31~2^31-1) 
unsigned long:0~4294967295(0~2^32-1) 
long:-2147483648~2147483647(-2^31~2^31-1) 
long long:-9223372036854775808~9223372036854775807(-2^63~2^63-1) 
unsigned long long:0~18446744073709551615(0~2^64-1)

__int64:-9223372036854775808~9223372036854775807(-2^63~2^63-1) 
unsigned __int64:0~18446744073709551615(0~2^64-1)

//—32位编译器—//(看这里就行了,与16位机,64位机比较,粗体为不同的,其余的都是相同)

char :1个字节
char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)(16位机,32位机,64位机各不相同)

short int : 2个字节
int: 4个字节(16位机是2B,32位&64位是4B)
unsigned int : 4个字节(16位机是2B,32位&64位是4B)

float: 4个字节
double: 8个字节

扫描二维码关注公众号,回复: 13173299 查看本文章

long: 4个字节
long long: 8个字节
unsigned long: 4个字节(16&32位是4B,64位是8B)

//—16位编译器—//

char :1个字节
char*(即指针变量): 2个字节
short int : 2个字节
int: 2个字节
unsigned int : 2个字节
float: 4个字节
double: 8个字节
long: 4个字节
long long: 8个字节
unsigned long: 4个字

https://blog.csdn.net/cyj2014go/article/details/78080279

猜你喜欢

转载自blog.csdn.net/qq_43033547/article/details/97483389