以下内容源于网络资源的学习与整理,如有侵权请告知删除。
1、整型数据int、long 所占字节数
早期的操作系统是16位系统,
int用二字节表示,范围是-32768~32767;
long用4字节表示,范围是-2147483648~2147483647。
后来发展到32位操作系统,
int 用4字节表示,与long相同。
目前的操作系统已发展到64位操作系统,但因程序编译工艺的不同,两者表现出不同的差别:
32位编译系统:int占四字节,与long相同。
64位编译系统:int占四字节,long占8字节,long数据范围变为:
−
2
63
˜
2
63
−
1
-2^{63} \~\ 2^{63-1}
−263 ˜263−1
long=long int
指针大小与系统编译器位数相同,16位编译器(2字节)、32位编译器(4字节)、64位编译器(8字节)
编码与中文:
Unicode/GBK: 中文2字节
UTF-8: 中文通常3字节,在拓展B区之后的是4字节
综上,中文字符在编码中占用的字节数一般是2-4个字节。
int,long int,short int的宽度都可能随编译器而异。但有几条铁定的原则(ANSI/ISO制订的):
sizeof(short int)<=sizeof(int)
sizeof(int)<=sizeof(long int)
short int至少应为16位(2字节)
long int至少应为32位。
下面给出不同位数编译器下的基本数据类型所占的字节数:
编译系统 | short(int) | int | long | long long | char | char *p | double | float |
---|---|---|---|---|---|---|---|---|
8位系统/编译器 | ||||||||
16位系统/编译器 | 2 | 2 | 4 | 8 | 1 | 2 | 8 | 4 |
32位系统/编译器 | 2 | 4 | 4 | 8 | 1 | 4 | 8 | 4 |
64位系统/编译器 | 2 | 4 | 8 | 8 | 1 | 8 | 8 | 4 |
2、32位系统下整型数据的取值范围
类型 | 范围 |
---|---|
int | -2147483648 ~ 2147483647 |
unsigned int | 0 ~ 4294967295 |
long | -2147483648 ~ 2147483647 |
unsigned long | 0 ~ 4294967295 |
long long | -9223372036854775808 ~ 9223372036854775807 |
unsigned long long | 0 ~ 1844674407370955161 |
__int64 | -9223372036854775808 ~ 9223372036854775807 |
unsigned __int64 | 0 ~ 1844674407370955161 |
3、Java基本类型占用的字节数
Java中一共有8种基本数据类型,其中有4种整型,2种浮点类型,1种用于表示Unicode编码的字符单元的字符类型和1种用于表示真值的boolean类型。(一个字节等于8个bit)
3.1.整型
类型 | 存储需求 | bit | 数值范围 | 备注 |
---|---|---|---|---|
int | 4字节 | 4*8 | ||
short | 2字节 | 2*8 | -32768~32767 | |
long | 8字节 | 8*8 | ||
byte | 1字节 | 1*8 | -128~127 |
3.2.浮点型
类型 | 存储需求 | bit | 数值范围 | 备注 |
---|---|---|---|---|
float | 4字节 | 4*8 | float类型的数值有一个后缀F(例如:3.14F) | |
double | 8字节 | 8*8 | 没有后缀F的浮点数值(如3.14)默认为double类型 |
3.3.char类型
类型 | 存储需求 | bit | 数值范围 | 备注 |
---|---|---|---|---|
char | 2字节 | 2*8 |
3.4.boolean类型
类型 | 存储需求 | bit | 数值范围 | 备注 |
---|---|---|---|---|
boolean | 1字节 | 1*8 | false、true |
补充:Java有一个能够表示任意精度的算书包,通常称为“大数值”(big number)。虽然被称为大数值,但它并不是一种Java类型,而是一个Java对象。
如果基本的整数和浮点数精度不能够满足需求,那么可以使用java.math包中的两个很有用的类:BigIntegerBigDecimal(Android SDK中也包含了java.math包以及这两个类)这两个类可以处理包含任意长度数字序列的数值。BigInteger类实现了任意精度的整数运算,BigDecimal实现了任意精度的浮点数运算。具体的用法可以参见Java API。
4、经验总结
-
运算需要低于十个数的时候用int,低于二十用 long/longlong
-
unsigned(无符号)类型范围 = 有符合类型的正数范围*2