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 不支持无符号整数。Integer 值的字长可以用常量 PHP_INT_SIZE来表示,自 PHP 4.4.0 和 PHP 5.0.5后,最大值可以用常量 PHP_INT_MAX 来表示。
版权声明:
1)原创作品,出自"CleverCode的博客",严禁转载,否则追究版权法律责任。
2)原创地址:http://blog.csdn.net/clevercode/article/details/46423103。
3)分类地址(PHP程序员技术精粹):http://blog.csdn.net/clevercode/article/category/3169943(博客持续增加,关注请收藏)。
4)欢迎大家关注CleverCode博客更多的精彩内容:http://blog.csdn.net/CleverCode。
5)欢迎大家关注CleverCode的微博:http://weibo.com/CleverCode。