• 关于perl bignum模块用法


    用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模块的使用。
  • 相关阅读:
    旋转骰子
    自我介绍
    【边带权 维护节点和根距离 两点距离】银河英雄传说
    【含义冲突判断】程序自动分析
    【01背包 合并费用】搭配购买
    【网格图环判断】格子游戏
    【连通块 维护size】 连通块中的点数
    【模板】 合并集合
    【出栈顺序判断】 Rails
    【整除分块】 余数之和
  • 原文地址:https://www.cnblogs.com/Mr-CHENs/p/6730601.html
Copyright © 2020-2023  润新知