PHP大数运算必须用GMP扩展:启用后以字符串初始化(如gmp_init('1234567890...')),用gmp_add等函数运算,结果用gmp_strval输出;禁用常规运算符,输入源头须保持字符串避免JSON自动转float。

PHP 默认整数类型在 32 位系统上最大为 2147483647,64 位系统上为 9223372036854775807,超出即溢出或自动转为 float(精度丢失)。所谓“piso 处理”应为笔误,实际指 **大数精确运算**,必须用 GMP 扩展——它不依赖 CPU 整数位宽,底层用字符串+算法实现任意精度整数运算。
确认 GMP 扩展已启用且可用
运行 php -m | grep gmp 或 extension_loaded('gmp') 检查。若未启用,需在 php.ini 中取消注释 extension=gmp(Linux)或 extension=php_gmp.dll(Windows),重启 PHP 进程。注意:Docker 官方镜像默认不含 GMP,需手动安装 apt-get install php-gmp 并重启 fpm。
用 gmp_init() 创建大数,别直接写数字字面量
直接写超大整数字面量(如 123456789012345678901234567890)会被 PHP 强制转成 float,精度已丢。必须用字符串初始化:
$a = gmp_init('123456789012345678901234567890');
$b = gmp_init('987654321098765432109876543210');
$result = gmp_add($a, $b); // 返回 GMP 对象
echo gmp_strval($result); // 输出字符串结果,避免隐式转换
-
gmp_init()第二个参数可指定进制(如16表示十六进制字符串) - 所有运算函数(
gmp_add、gmp_mul、gmp_pow等)只接受 GMP 资源或字符串,不接受 float 或超限 int - 输出务必用
gmp_strval(),而非(string)强转——后者在某些旧版本中可能截断
常见运算场景与易错点
大数比较、取模、位运算等操作不能用常规 PHP 运算符(==、%、&),必须调用对应 GMP 函数:
立即学习“PHP免费学习笔记(深入)”;
- 比较:
gmp_cmp($a, $b)返回 -1/0/1,不能用=== - 取模:
gmp_mod($a, $b)(正余数),gmp_div_qr()可同时得商和余数 - 幂运算:
gmp_pow($base, $exp)仅支持整数指数;超大指数需用gmp_powm()(带模幂)防内存爆炸 - 进制转换:
gmp_strval($num, 16)转十六进制,gmp_init('ff', 16)从十六进制解析
特别注意:GMP 函数返回的不是普通整数,是资源或对象(PHP 8.0+ 为 GMP 类实例),任何中间结果若被意外转成 int/float 就前功尽弃。
真正麻烦的不是调用函数,而是整个数据流必须从输入源头就保持 GMP 类型——读文件、接 API、解 JSON 时,大数字段必须作为字符串接收,再传给 gmp_init();一旦进过 json_decode() 默认解析,就不可逆地变 float 了。










