用bignum处理大数:
对于32位的perl来说,他的整数范围被限定在32位。
perl -le "print 873498127389471892374891723489172389407128947891234" 8.73498127389472e+50 打印的结果为科学记数法显示 |
在perl中使用bignum模块可以解决数据精度缺失的问题。
我们来看两个例子:
对比上述结果可以看到,当加入bignum后,不再使用科学计数法显示结果,程序可以计算任意大小的数字,不管是浮点还是整数,都可以自动处理。由于底层系统对数据类型本身大小的限制,使用任意大的数字会让程序运行耗费更多的硬件资源和时间,这是追求精确结果的必然代价。
限制bignum的作用范围:
一旦启用bignum所有的数字和数学计算都会使用大数形式。因为bignum运算每次都会将数字转换成Math::BigInt或Math::BigFloat对象。这会极大地影响性能,因为所有的计算都变成了对象方法调用。
如果程序中大部分都需要用到bignum,那么小范围不用的地方可以用no bignum 指令临时关闭。同样的道理,如果我们只是想在程序的小范围内使用bignum那么可以局部开启
{
use bignum;#or no bignum;
代码块
}
如果只有某些特定的数据需要使用bignum,那么可以构建对象的方式表示大数,对象的操作方法一如既往,而对于大数的特别处理也仅仅发生在这些对象上。
弊端:
上面已经说过,当使用bignum时对于任意大数字会让程序耗费更多的硬件资源和时间。所以在使用过程中需要根据实际情况灵活的来限定bignum模块的使用。