网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
所以这种数据类型转化虽然不会出现代码错误,但肯定是无法满足业务需求的,因为这在浮点数转化整数的过程中会自动舍去小数,造成数据失真!
二、隐式类型提升产生的异常
除了上述这种直接数据类型转化的操作会导致数据精度丢失之外,下面这种计算也可能会让数据出现错误情况。
**double** d = 3.14;
**int** i = 3;
i += d;
System.out.println(i); // 结果为6
在我们平时的印象中,int类型和double类型进行计算,结果应该为double类型数据,这是不能够使用int类型接收计算结果的。
但如果我们使用自增符号(+=)却可以通过编译,并且会去除小数得到一个整数,这也是我们平时可能容易忽略的地方,这里也可能会造成严重的后果的一个小细节。
三、数据范围越界产生的异常
另外我们可能也会碰到下面这样的异常情况:第一行不报错,第三行报错
**long** l = 1000000000; //不会保错
**long** ll = 10000000000; // 会报错
之所以会产生上述情况,我们首先要看看两个值分别是多少,l变量值为10亿,ll变量值为100亿,这是第一点。
第二点,两个变量的数据类型都是long,但定义的值后面没有加L或者l,所以此时这两个变量默认的数据类型就是int。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**