数据类型字节长度表(32位机)

本文详细介绍了 C++ 中各种数据类型的字节数、取值范围及别名等内容,包括整型、浮点型、布尔型等基本数据类型,并对每种类型进行了说明。
数据类型名称 字 节数 别 名 取值范围
int * signed,signed int 操作系统决定,即与操作系统的"字长"有关
unsigned int * unsigned 由操作系统决定,即与操作系统的"字长"有关
__int8 1 char,signed char –128 到 127
__int16 2 short,short int,signed short int –32,768 到 32,767
__int32 4 signed,signed int –2,147,483,648 到 2,147,483,647
__int64 8 –9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
bool 1 false 或 true
char 1 signed char –128 到 127
unsigned char 1 0 到 255
short 2 short int,signed short int –32,768 到 32,767
unsigned short 2 unsigned short int 0 到 65,535
long 4 long int,signed long int –2,147,483,648 到 2,147,483,647
long long 8 none (but equivalent to __int64) –9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
unsigned long 4 unsigned long int 0 到 4,294,967,295
enum * 由操作系统决定,即与操作系统的"字长"有关
float 4 3.4E +/- 38 (7 digits)
double 8 1.7E +/- 308 (15 digits)
long double 8 1.7E +/- 308 (15 digits)
wchar_t 2 __wchar_t 0 到 65,535

类型标识符类型说明长度 (字节)范围备注
char字符型1-128 ~ 127-27 ~ (27 -1)
unsigned char无符字符型10 ~ 2550 ~ (28 -1)
short int短整型2-32768 ~ 327672-15 ~ (215 - 1)
unsigned short int无符短整型20 ~ 655350 ~ (216 - 1)
int整型4-2147483648 ~ 2147483647-231 ~ (231 - 1)
unsigned int无符整型40 ~ 42949672950 ~ (232-1)
float实型(单精度)41.18*10-38 ~ 3.40*10387位有效位
double实型(双精度)82.23*10-308 ~ 1.79*1030815位有效位
long double实型(长双精度)103.37*10-4932 ~ 1.18*10493219位有效位
### MySQL 数据类型及其对应的字节长度 #### 整型数据类型 - `TINYINT`:占用1个字节,范围是从-128到127(有符号),或从0至255(无符号)。[^3] - `SMALLINT`:占用2个字节,范围是从-32,768到32,767(有符号),或从0至65,535(无符号)。 - `MEDIUMINT`:占用3个字节,范围是从-8,388,608到8,388,607(有符号),或从0至16,777,215(无符号)。 - `INT` 或者 `INTEGER`:占用4个字节,范围是从-2^31 到 (2^31)-1 (有符号),或从0 至 (2^32)-1(无符号)。 - `BIGINT`:占用8个字节,范围是从-(2^63)(2^63)-1(有符号),或从0 至 (2^64)-1(无符号)。 #### 字符串数据类型 - `CHAR(M)` 和 `VARCHAR(M)` 中的 M 示字符的最大数量而非字节数量;如果存储的是多字节字符集下的字符串,则实际使用的空间可能会超过 M 个字节。例如,在 UTF8 编码下,一个汉字占三个字节置。因此,对于 `CHAR(m)` 类型来说,它总是固定分配 m * max_bytes_per_character 的字节给定列,而不论实际输入了多少个字符;而对于 `VARCHAR(m)` 来说,只会为实际存入的内容动态分配相应大小的空间加上额外的一个或两个字节来记录内容的实际长度。[^4] ```sql CREATE TABLE example ( id INT, name VARCHAR(50), -- 可变长度字符串,最多可容纳50个字符 fixed_name CHAR(50) -- 固定长度字符串,始终预留50个字符); ``` #### 浮点数和定点数 - `FLOAT[(M,D)]`:通常实现为单精度浮点数值,默认情况下大约需要4个字节。 - `DOUBLE[(M,D)]`:双精度浮点数值,默认情况约为8个字节。 - `DECIMAL(P,D)` / `NUMERIC(P,D)` :P 是总数 D 小数部分后的数。每个 DECIMAL 值都作为一系列 ASCII 数字保存在一个二进制字符串中,并且每9个十进制数字使用四个字节。[^2]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值