数据类型与字节长度

位(Bit)、字节(Byte)、字(Word)

位:"位(bit)"是电子计算机中最小的数据单位。每一位的状态只能是0或1。

字节:8个二进制位构成1个"字节(Byte)",它是存储空间的基本计量单位。1个字节可以储存1个英文字母或者半个汉字,换句话说,1个汉字占据2个字节的存储空间。

字:"字"由若干个字节构成,字的位数叫做字长,不同档次的机器有不同的字长。例如一台8位机,它的1个字就等于1个字节,字长为8位。如果是一台16位机,那么,它的1个字就由2个字节构成,字长为16位。字是计算机进行数据处理和运算的单位。

数据类型对应字节数

不同的平台上对不同数据类型分配的字节数是不同的。
常用数据类型对应字节数可用如 sizeof(char),sizeof(char*) 等得出。

类型32位机器64位机器
char11
char*48
BOOL11
bool11
int44
short22
long48
long long88
NSInteger48
float44
double88
CGFloat48

⚠️注意:

  • char* 即指针变量,32 位的寻址空间是 2^32, 即 32 个 bit,也就是 4 个字节,同理 64 位编译器。
  • 加 unsigned 与未加 unsigned 所占字节大小相同。
  • NSInteger在32位机器被定义为int,在64位机器被定义为long。
  • NSUInteger在32位机器被定义为unsigned int,在64位机器被定义为unsigned long。
  • CGFloat在32位机器被定义为float,在64位机器被定义为double。
  • 除 long 外,其他 C 语言类型不管在哪种编译器下,都保持一样的长度。
### 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、付费专栏及课程。

余额充值