Deprecated: Optional parameter $keys declared before required parameter $cms_id is implicitly treated as a required parameter in /home/www/dev/work/class/blog/CmsKey.php on line 75

Deprecated: Creation of dynamic property lvesu\lvesu\controller\blog\php::$title is deprecated in /home/www/dev/work/website/lvesu/class/controller/blog/php.php on line 28

Deprecated: Creation of dynamic property lvesu\lvesu\controller\blog\php::$outlink is deprecated in /home/www/dev/work/website/lvesu/template/blog/cms/php.manual.tpl on line 2

Deprecated: Creation of dynamic property lvesu\lvesu\controller\blog\php::$status is deprecated in /home/www/dev/work/website/lvesu/template/blog/index.head.php on line 2
PHP - Manual: intdiv - 互联网笔记

略微加速

PHP官方手册 - 互联网笔记

PHP - Manual: intdiv

2025-10-24

intdiv

(PHP 7, PHP 8)

intdiv对除法结果取整

说明

intdiv(int $num1, int $num2): int

返回 num1 除以 num2 商数的整数部分。

参数

num1

被除数。

num2

除数。

返回值

num1 除以 num2 的商,对该商取整。

错误/异常

如果 num20,将抛出 DivisionByZeroError 异常。如果 num1PHP_INT_MIN 并且 num2-1,将抛出 ArithmeticError 异常.

示例

示例 #1 intdiv() 的一些示例

<?php
var_dump
(intdiv(3, 2));
var_dump(intdiv(-3, 2));
var_dump(intdiv(3, -2));
var_dump(intdiv(-3, -2));
var_dump(intdiv(PHP_INT_MAX, PHP_INT_MAX));
var_dump(intdiv(PHP_INT_MIN, PHP_INT_MIN));
var_dump(intdiv(PHP_INT_MIN, -1));
var_dump(intdiv(1, 0));
?>
int(1)
int(-1)
int(-1)
int(1)
int(1)
int(1)

Fatal error: Uncaught ArithmeticError: Division of PHP_INT_MIN by -1 is not an integer in %s on line 8
Fatal error: Uncaught DivisionByZeroError: Division by zero in %s on line 9

参见

  • /——浮点除法
  • %——整数取模
  • fmod() - 返回除法的浮点数余数——浮点数取模
添加备注

用户贡献的备注 2 notes

up
42
AmeenRoss
9 years ago
This does indeed seem to be equal to intdiv:

<?php
function intdiv_1($a, $b){
return (
$a - $a % $b) / $b;
}
?>

However, this isn't:

<?php
function intdiv_2($a, $b){
return
floor($a / $b);
}
?>

Consider an example where either of the parameters is negative:
<?php
$param1
= -10;
$param2 = 3;
print_r([
'modulus' => intdiv_1($param1, $param2),
'floor' => intdiv_2($param1, $param2),
]);

/**
* Array
* (
* [modulus] => -3
* [floor] => -4
* )
*/
?>
up
5
oittaa
3 years ago
Python style integer division, where the result is always rounded towards minus infinity.

1 // 2 is 0
(-1) // 2 is -1
1 // (-2) is -1
(-1) // (-2) is 0

<?php
function intdiv_py(int $num1, int $num2): int{
if (
$num1 < 0 xor $num2 < 0){
$num1 = abs($num1);
$num2 = abs($num2);
$remainder = $num1 % $num2;
return
$remainder ? -1 -($num1 - $remainder) / $num2 : -$num1 / $num2;
}
return
intdiv($num1, $num2);
}

var_dump(intdiv_py(1, 2)); // 0
var_dump(intdiv_py(-1, 2)); // -1
var_dump(intdiv_py(1, -2)); // -1
var_dump(intdiv_py(-1, -2)); // 0
?>

官方地址:https://www.php.net/manual/en/function.intdiv.php

北京半月雨文化科技有限公司.版权所有 京ICP备12026184号-3