【java基础复习】如何理解java中基本数据类型里的自动类型提升和强制类型转换?

  • 自动类型提升
  • 强制类型转换
  • 注意事项 ❗
  • 感谢

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类型。

让我们来看几个示例:

【java基础复习】如何理解java中基本数据类型里的自动类型提升和强制类型转换?_第1张图片

可以看到,我们byte类型的变量b1和short类型的变量s1在做运算时,它们的结果不能是short类型,而自动提升为int类型。

【java基础复习】如何理解java中基本数据类型里的自动类型提升和强制类型转换?_第2张图片

可以看到,int类型的变量和long类型的变量做运算时,它们的结果自动提升为两者中较大的long类型。

【java基础复习】如何理解java中基本数据类型里的自动类型提升和强制类型转换?_第3张图片

同理,在上面的演示中,long类型的变量和float类型的变量做运算时,它们的结果自动提升为较大的float类型。

强制类型转换

与自动类型提升相反,强制类型转换通常用于将高精度(高容量)的数据类型转换为低精度(低容量)的数据类型。但需要注意潜在的数据精度的损失。

强制类型转换需要程序员明确指定要进行的转换,并使用圆括号将目标数据类型括起来。

让我们来看几个示例:

【java基础复习】如何理解java中基本数据类型里的自动类型提升和强制类型转换?_第4张图片

在上面的示例中,l1和f1的运算结果是float类型的,如果要转换为低精度的long类型,需要手动实现强制类型转换。

【java基础复习】如何理解java中基本数据类型里的自动类型提升和强制类型转换?_第5张图片

在上面的示例中,从double到Int的类型转换就导致了小数部分的精度损失。

注意事项 ❗

  • 有一个点需要格外注意。在java中,常量或者说是字面量的默认数据类型是Int(如果是整型)和double(如果是浮点型)。

    示例:
    【java基础复习】如何理解java中基本数据类型里的自动类型提升和强制类型转换?_第6张图片

  • 自动类型提升是隐式的,而强制类型转换是显式的。强制类型转换提供了更大的控制力,但也需要更多的注意和谨慎

  • 强制类型转换可能导致数据损失。因此,应该仔细考虑何时使用它,确保不会丢失重要的信息

  • 还有一个小细节,给long类型数据变量赋值时,最好养成加 L(l) 后缀的习惯,如果不加L,在数据的大小不超过int数据类型范围的时候是OK的,一旦超过了,那么不加L就会出现编译失败这个错误。

    在给float类型数据变量赋值时,必须要添加 F(f) 后缀,否则一定会报错!

感谢

好啦,这次的分享就到这里,感谢大家看到这里

你可能感兴趣的:(java,复习)