Java是一种强类型语言, 这就意味着必须为每一个变量声明一种类型.
Java中一共有8中基本类型:
- 4种整型:
整型: 用于表示没有小数部分的数值, 允许为负数
类型 存储需求 取值范围
int: 4字节 -2 147 483 648 ~ 2 147 483 647 (正好超过20亿)
short: 2字节 -32 768 ~ 32 767
long: 8字节 -9 223 372 036 854 775 808 ~ 9 223 372 036 854 775 807
byte: 1字节 -128 ~ 127
- 2种浮点类型:
- 用于表示有小数部分的数值.
类型 存储需求 取值范围
float 4字节 大约 ±3.402 823 47E + 38F(有效位数为 6 ~ 7 位)
double 8字节 大约 ±1.797 693 134 862 315 70E + 308(有效位数为15位)
- double表示这种类型的数值精度是float类型的两倍(双精度数值), 大部分程序都采用double类型.
- float类型的数值有一个后缀F, 没有后缀F的浮点数值默认为double类型.可以在浮点数值后面添加后缀D表示double.
- 表示溢出和出错情况的三个特殊的浮点数值:
正无穷大
负无穷大
NaN
- 一个正整数除以0: 正无穷大
- 0/0, 负数的平方根结果为NaN
- 浮点数值不适用于禁止出现摄入误差的金融计算中, System.out.pritln(2.0-1.1) 将打印出0.8999999999999999, 而不是0.9
- 浮点数值采用二进制系统表示, 而在二进制系统中无法精确的表示分数1/10.
- 如果需要在数值计算中不含有任何舍入误差,应使用BigDecimal类
- 1种用于表示Unicode编码的字符单元的字符类型char
用于表示单个字符, 通常用来表示字符常量, 建议不要在程序中使用char类型
- 1种用于表示真值的boolean类型
boolean类型由两个值: false, true, 用来判定逻辑条件.
整型值和布尔值之间不能进行相互转换. 不能使用if(x = 0), x=0不能转换为布尔值.
数值类型之间的转换
- 合法转换:
- 无信息丢失的转换:
byte -> short -> int -> long
char -> int
int -> double
- 可能有精度损失的转换:
int -> float
long -> float
long -> double
- 两个数值进行二元操作时, 先要将两个操作数转换为同一种类型, 然后再进行计算.
1. 如果两个操作数中有一个是double类型, 另一个操作数就会转换为double类型.
2. 否则, 如果其中一个操作数是float类型, 另一个操作数将会转换为float类型.
3. 否则, 如果其中一个操作数是long类型, 另一个操作数将会转换为long类型.
4. 否则, 两个操作数都将转换为int类型
- 强制类型转换
圆括号中给出想要转换的目标类型, 后面紧跟待转换的变量名.
double x = 9.997;
int nx = (int) x; // nx is 9
int nx = (int) Math.round(x); // 四舍五入, 再转为整型
Math.round() 返回的是long类型, 由于存在信息丢失的可能性, 所以只有使用显式的强制类型转换才能够将long类型转换成int类型.
注意: 将一个数值从一种类型强制转换为另一种类型, 而又超出了目标类型的表示范围, 会截断为一个完全不同的值.
不要在boolean类型与数值类型之间进行强制类型转换, 防止发生错误.