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."\r\n"; $value = (int)$id;
echo '(int)$id:'.$value."\r\n"; $value = intval($id);
echo 'intval($id):'.$value."\r\n"; $value = filter_var($id, FILTER_VALIDATE_INT);
echo 'filter_var($id, FILTER_VALIDATE_INT):'."\r\n";
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."\r\n"; $value = (int)$id;
echo '(int)$id:'.$value."\r\n"; $value = intval($id);
echo 'intval($id):'.$value."\r\n"; $value = filter_var($id, FILTER_VALIDATE_INT);
echo 'filter_var($id, FILTER_VALIDATE_INT):'."\r\n";
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。