请教大家一个问题,,,
public class IntegerTest {
public static void main(String[] args) {
short short_test;
int int_test;
float float_test;
short_test=100;//为什么这个可以编译通过? 100默认不是int 类型的吗?
//float_test=1.2;
int_test=50;
short_test=int_test;//为什么这个就会报非运行时异常.
System.out.println(short_test);
}
百度上我也搜了 ,都没有从问题的本质出发,我想知道他们底层是怎么实现的. 顺便也分析下byte 谢谢.
------解决方案--------------------
short_test=100;//为什么这个可以编译通过? 100默认不是int 类型的吗?
照你这么说,short类型就没法赋值了?
short s = 1;不是一样的道理?
只要在short的范围以内,就可以直接赋值。
short_test=int_test;//为什么这个就会报非运行时异常.
int_test是一个变量,编译期只知道这是一个int,又不知道这个int到底是多大,那么,到底short到底能不能容下这个int呢?编译器崩溃了!编译期不是神啊!
------解决方案--------------------
呵呵,我们也刚好学到这里的样子,我们老师是这么解释的
byte,short,char取值范围内的字面常量(字面常量懂不?就是数字本身)可以直接赋值,如果超出了他们的取值范围,需要进行强制转换。但是如果是把一个变量赋值给这些类型的变量,则会报丢失精度的错误。
eg:
byte b =127; //ok
byte b = 128;//error code
byte b =(byte)128//ok,结果是-128,因为强制转换丢失了精度
float float_test=1.2
这样子赋值是不可以的,尽管1.2在float所能表示的取值范围内,因为整数和小数的二进制表示不一样
eg:
byte b1=1;
把一赋值给byte型变量,用32位表示的int 1是前面31个0,最后一个为1
用byte来存储的时候,取32位的低8位,即 0000 0001,大小没有改变
为什么小数不行,建议你自己去看看小数的二进制表示咯
有些东西可以当作规律或者语法记下来,没必要追根究底,因为有些东西挖的太深,对我们初学者来说会很吃力呵呵