今天在复习Java的时候看到一些和我一直以来想象中不一样的东西,特记录下来。
在许多计算机语言中,往往都有基本数据类型之间的自动转换。比如
int a = 1;
double b = 3.2d;
System.out.println(a + b);
在执行a+b的时候,a首先会先转换成double,再和b进行加法运算。也就是说,当两个不同类型的数进行基本运算符操作时,精度小的那个数会首先转换成精度大的数的类型再进行计算。
Java中类型转换图如下:
图中实箭头表示无精度损失转换,虚线表示有精度缺失转换。
课件中对转换有如下概括:
- If either of the operands is of type double, the other one will be
converted to a double.- Ohterwise, if either of the operands is of type float, the other one
will be converted to a float.- Ohterwise, if either of the operands is of type long, the other one
will be converted to a long.- Ohterwise, both operands will be converted to an int.
前三点都知道,重要的是第四点,这才是和我一直以来想象不一样的地方:否则,两个操作数都要转换成int。
也就是说,即使是两个byte或short进行运算,也都要转换成int。于是我做了个实验:
当我想把两个byte相加并赋给另一个byte的时候,编译器就给出错误了:要求等号后面是byte,但发现了int。
也就是说,当我们有byte或short类型的数时,一旦对它们进行了基本运算符操作,结果就成了int。想不通为什么要做这样的处理,希望在以后能找到答案把。
好好学习一门语言还是挺有帮助的,虽然做过些Android项目,但对Java没有系统学习,很多基本的东西还处于“我觉得”的状态,经过半个学期的Java课程学习,发现脑子里很多Java内容清晰了许多。一直觉得语言的课没什么好学的,现在打脸了。看来还是得谦虚点,好好学习。