php 小数取余数,php 浮点数取余的方法

浮点型(也叫浮点数 float,双精度数 double 或实数 real。浮点数的字长和平台相关,尽管通常最大值是 1.8e308 并具有 14 位十进制数字的精度(64 位 IEEE 格式)。

浮点数的精度有限。尽管取决于系统,PHP 通常使用 IEEE 754 双精度格式,则由于取整而导致的最大相对误差为 1.11e-16。非基本数学运算可能会给出更大误差,并且要考虑到进行复合运算时的误差传递。

此外,以十进制能够精确表示的有理数如 0.1 或 0.7,无论有多少尾数都不能被内部所使用的二进制精确表示,因此不能在不丢失一点点精度的情况下转换为二进制的格式。

这就会造成混乱的结果:

例如,floor((0.1+0.7)*10)通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999999991118...。

所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。

本文实例讲述了php 浮点数取余的方法。

分享给大家供大家参考,具体如下:

一般我们进行取余运算第一个想到的就是用百分号%,但当除数是个很大的数值,超出了int范围时,这样取余就不准确了。

php大数(浮点数)取余函数:/**

* php大数取余

*

* @param int or float $bn 除数

* @param int $sn 被除数

* @return int 余数

*/

//大数(浮点数)取余方法

function Kmod($bn, $sn) {

return intval(fmod(floatval($bn), $sn));

}

测试代码://大数(浮点数)取余方法

function Kmod($bn, $sn) {

return intval(fmod(floatval($bn), $sn));

}

//整数取余方法

function mod($bn, $sn) {

return $bn%$sn;

}

//最大的int整数

$bn = PHP_INT_MAX;

$sn = 11;

var_dump($bn);

var_dump(Kmod($bn, $sn));

var_dump(mod($bn, $sn));

//给最大的int整数加1

$bn = PHP_INT_MAX + 1;

var_dump($bn);

var_dump(Kmod($bn, $sn));

var_dump(mod($bn, $sn));

执行结果:int 2147483647

int 1

int 1

float 2147483648

int 2

int -2

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值