对于编程初学者来说,很容易忽略表达式计算得到的结果的类型,从而用一个变量去接收那个表达式,得到一个错误的结果。


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


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

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





显示结果为 0.0;


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




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




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


正确代码如下:




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






得到正确结果 0.5 。