对于编程初学者来说,很容易忽略表达式计算得到的结果的类型,从而用一个变量去接收那个表达式,得到一个错误的结果。
比如说,一个整型和一个双精度浮点型相加,得到的是一个双精度浮点型变量,如果用整型变量去接收它,必然会失去小数点后面的数。这个错误比较明显,有的语言的编译器甚至通不过编译,犯错的概率也比较低。
这里我想特别强调一种情况,这种情况很多见,也很容易犯。亲身体验过这种情况,当时做一个关于数据包调度算法的期末作业,其中有个算丢包率的过程,丢包率= (丢的包的数量)/(所有包的数量),如果用一下代码去计算它,就会得到错误的结果(代码用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 。