首页 > 其他 > 详细

关于perl bignum模块用法

时间:2017-04-18 22:05:16      阅读:208      评论:0      收藏:0      [点我收藏+]
用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模块的使用。

关于perl bignum模块用法

原文:http://www.cnblogs.com/Mr-CHENs/p/6730601.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!