- 自动类型提升
- 强制类型转换
- 注意事项 ❗
- 感谢 💖
Java是一种强类型语言,这意味着在编写代码时,需要明确指定每个变量的数据类型。我们知道,java中有八大基本数据类型。分别是:
数据类型 | 大小(字节数) | 范围 |
---|---|---|
byte | 1字节 | -128 到 127 |
short | 2字节 | -32,768 到 32,767 |
int | 4字节 | -2,147,483,648 到 2,147,483,647 |
long | 8字节 | -9,223,372,036,854,775,808 到 9,223,372,036,854,775,807 |
float | 4字节 | 大约 ±3.40282347 x 10^38(7位有效数字) |
double | 8字节 | 大约 ±1.7976931348623157 x 10^308(15位有效数字) |
char | 2字节 | 0 到 65,535(Unicode字符) |
boolean | 不定(通常1比特位) | true 或 false |
在实际编程中,我们常常需要在不同的数据类型之间进行转换。Java提供了两种主要的数据类型转换方式:自动类型提升和强制类型转换。
注意:这里的数据类型转换只涉及七种基本数据类型之间的转换,不包含boolean类型的。
自动类型提升
自动类型提升是Java中的一种隐式类型转换。它会自动将容量(精度)小的数据类型提升为容量(精度)大的数据类型。
注意:这里的容量(精度)大小指的是数据类型可表示的数据的范围的大小而不是内存大小。比如float虽然是4字节的,long是8字节的,但是float的容量(精度)大于long的容量(精度),即float的数据范围大于long的数据范围。
七种数据类型的容量(精度)大小排序如下:
byte、char、short –> int –> long –>float –> double
需要注意,所有的byte、short和char类型都会自动提升为int类型。
让我们来看几个示例:
可以看到,我们byte类型的变量b1和short类型的变量s1在做运算时,它们的结果不能是short类型,而自动提升为int类型。
可以看到,int类型的变量和long类型的变量做运算时,它们的结果自动提升为两者中较大的long类型。
同理,在上面的演示中,long类型的变量和float类型的变量做运算时,它们的结果自动提升为较大的float类型。
强制类型转换
与自动类型提升相反,强制类型转换通常用于将高精度(高容量)的数据类型转换为低精度(低容量)的数据类型。但需要注意潜在的数据精度的损失。
强制类型转换需要程序员明确指定要进行的转换,并使用圆括号将目标数据类型括起来。
让我们来看几个示例:
在上面的示例中,l1和f1的运算结果是float类型的,如果要转换为低精度的long类型,需要手动实现强制类型转换。
在上面的示例中,从double到Int的类型转换就导致了小数部分的精度损失。
注意事项 ❗
-
有一个点需要格外注意。在java中,常量或者说是字面量的默认数据类型是Int(如果是整型)和double(如果是浮点型)。
示例:
-
自动类型提升是隐式的,而强制类型转换是显式的。强制类型转换提供了更大的控制力,但也需要更多的注意和谨慎
-
强制类型转换可能导致数据损失。因此,应该仔细考虑何时使用它,确保不会丢失重要的信息
-
还有一个小细节,给long类型数据变量赋值时,最好养成加 L(l) 后缀的习惯,如果不加L,在数据的大小不超过int数据类型范围的时候是OK的,一旦超过了,那么不加L就会出现编译失败这个错误。
在给float类型数据变量赋值时,必须要添加 F(f) 后缀,否则一定会报错!
感谢 💖
好啦,这次的分享就到这里,感谢大家看到这里🤞