标签:编译 最小 超过 inf src 现在 false 问题: 最小值
java的数据类型分为两大类:基本数据类型和引用数据类型
这里我们先说一下基本数据类型,基本数据类型分为四种:整型、浮点型、字符型、布尔类型
(1)整型根据取值范围从小到大依次为:byte、short、int、long
1.一般情况下,整型类型的数值默认为int类型;通常情况下,取值范围大的类型转换为小的类型时处出现问题,程序如下所示:
public static void main(String[] args){
int x = 127;
byte y = x;
System.out.println(y);
}
这个时候编译并运行程序会报错,因为从取值范围大的类型转换成取值范围小的类型会有损失,即使你这个值在取值范围小的类型中。

要想从取值范围大的类型转换成取值范围小的类型不报错,需要通过强制转换,程序如下所示:
public static void main(String[] args){
int x = 127;
byte y = (byte)x;
System.out.println(y);
}
程序编译并运行成功

2.现在是因为值小,所以没有造成数据损失,下面列举一个会出现数据损失的问题:
public static void main(String[] args){
int x = 128;
byte y = (byte)x;
System.out.println(y);
}
这个时候输出结果就出现问题了,因为需要强制转换的值已经超过了byte类型的最大值,需要注意的一点是,当一个值的大小超过了数据类型的范围时,
超出多少,就是在最小值的基础上加上超出的这个值,最后得出的值就是结果

3.不同类型的值在进行运算时,所得结果会自动转换为取值范围大的类型,程序如下:
public static void main(String[] args){
int x = 1;
byte y = 127;(byte类型的最大值)
System.out.println(x+y);
}
程序编译运行后的结果如下,输出128的原因是因为int类型与byte类型进行运算时,结果自动转换为了int类型,所以输出结果为128

(2)浮点型:double和float
double的取值范围比float类型的取值范围大很多,所以当写一个小数时,默认为double类型
public static void main(String[] args){
float x = 1.0;
System.out.println(x);
}
将该程序编译后会报错,因为带小数的值默认为double类型,又因为double类型的范围比float大,所以在编译过程中会报错

但是你要是这样写 float x = 1.0f 就不会报错了,这样写表明该值为float类型的
(3)字符型:char
字符类型的值用" ‘ " 表示,即char x = ‘A‘ ,要注意的是字符类型的值会与数字相对应,即每个字符会对应一个数字,程序如下:
public static void main(String[] args){
char x = ‘A‘;
char y = ‘a‘;
System.out.println("A:"+(int)x);
System.out.println("a:"+(int)y);
}
程序编译并运行后,输出结果如下:

注意:‘0‘与0 的值不一样,感兴趣的可以试一试
(4)布尔类型:有两个值 true 和 false
一般该类型用于逻辑判断,程序如下:
public static void main(String[] args){
boolean x = true;
if(x){
System.out.println("true");
}
}
程序编译并运行后输出结果如下:

标签:编译 最小 超过 inf src 现在 false 问题: 最小值
原文地址:https://www.cnblogs.com/li666/p/11804373.html