Java基础篇笔记(二) ---容易忽视的表达式结果的类型,求概率、几率问题

来源:互联网 发布:无线通信网络安全技术 编辑:IT博客网 时间:2019/07/20 17:10
对于编程初学者来说,很容易忽略表达式计算得到的结果的类型,从而用一个变量去接收那个表达式,得到一个错误的结果。


比如说,一个整型和一个双精度浮点型相加,得到的是一个双精度浮点型变量,如果用整型变量去接收它,必然会失去小数点后面的数。这个错误比较明显,有的语言的编译器甚至通不过编译,犯错的概率也比较低。


这里我想特别强调一种情况,这种情况很多见,也很容易犯。亲身体验过这种情况,当时做一个关于数据包调度算法的期末作业,其中有个算丢包率的过程,丢包率= (丢的包的数量)/(所有包的数量),如果用一下代码去计算它,就会得到错误的结果(代码用Java表示)。


public class Test{public static void main (String args[]){int lostPacket = 1;            //表示丢包的数量,这里简化,直接赋值为1int allPacket = 2;//表示所有包的数量,这里简化,直接赋值为2double lostPercent = lostPacket / allPacket ;          //丢包率System.out.println(lostPercent);}}



显示结果为 0.0;
除数和被除数都是整型,然后用一个双精度浮点型变量去接收这个丢包率,得到的永远是0。看似简单的问题,如果在编码的时候不注意,就会犯下和我一样的错误。


这种问题可以归纳为算概率问题,或者说是算几率的问题。概率或者几率是用浮点型表示的,如果除数和被除数都是整型,写代码又有我上述的错误,那么得到的结果永远都是0。如果除数和被除数也都是浮点型,那么不会出现上述错误。


该注意的是第一种情况,也是比较容易发生的情况。写代码的时候务必要先将除数或者被除数转换成浮点型。
正确代码如下:


public class Test{public static void main (String args[]){int lostPacket = 1;            //表示丢包的数量,这里简化,直接赋值为1int allPacket = 2;//表示所有包的数量,这里简化,直接赋值为2double lostPercent =(double) lostPacket /(double) allPacket ;          //丢包率System.out.println(lostPercent);}}




得到正确结果 0.5 。