CleverCode最近遇到一个PHP项目整形转化问题,mysql有一个字段id是bigint的,里面有长整型,如id = 5147486396。但是php代码由于历史原因却部署在多台机器中,其中A机器32位系统中,B机器64系统中。现在的问题是64系统中页面访问正常。32位系统中访问出错了。原因是php整形溢出。1 A机器演示1.1 获取A机器系统位数# getconf LONG_BIT
1.2 整形转化代码<?php
$id = 5147486396;
echo '$id:'.$id."
";
$value = (int)$id;
echo '(int)$id:'.$value."
";
$value = intval($id);
echo 'intval($id):'.$value."
";
$value = filter_var($id, FILTER_VALIDATE_INT);
echo 'filter_var($id, FILTER_VALIDATE_INT):'."
";
var_dump($value);
?> 1.3 运行结果(int)5147486396的结果是852519100,intval(5147486396)的结果是852519100,filter_var(5147486396, FILTER_VALIDATE_INT)结果是false。
2 B机器演示2.1 获取B机器系统位数# getconf LONG_BIT
2.2 整形转化代码<?php
$id = 5147486396;
echo '$id:'.$id."
";
$value = (int)$id;
echo '(int)$id:'.$value."
";
$value = intval($id);
echo 'intval($id):'.$value."
";
$value = filter_var($id, FILTER_VALIDATE_INT);
echo 'filter_var($id, FILTER_VALIDATE_INT):'."
";
var_dump($value);
?> 2.3 运行结果(int)5147486396的结果是5147486396,intval(5147486396)的结果是5147486396,filter_var(5147486396, FILTER_VALIDATE_INT)结果是5147486396。
3 结论 整型数的字长和平台有关,尽管通常最大值是大约二十亿(32 位有符号)。64 位平台下的最大值通常是大约 9E18。PHP 不支持无符号。 值的字长可以用 PHP_INT_SIZE来表示,自 PHP 4.4.0 和 PHP 5.0.5后,最大值可以用常量 PHP_INT_MAX 来表示 |