小心 int 乘法溢出!
浏览:1252次 出处信息
C/C++ 语言里, 绝大部分平台上 int 类型是 32 位的, 无论你的操作系统是否是 64 位的. 而一些常用的函数, 如 malloc(), 它接受的参数是 size_t 类型:
void * malloc ( size_t size );
如果你写出这样的代码:
int mb = 3000; // 3000MB ~= 3GB void *p = malloc(mb * 1024 * 1024); // WRONG!
这是非常危险的, 因为那个乘法得到的结果也是 int 类型, 但已经溢出了, 所以
mb * 1024 * 1024 = -1073741824;
然后
malloc(-1073741824) = malloc((size_t)-1073741824);
在 64 位系统里, size_t 是 64 位正整数, 所以
(size_t)-1073741824 = 18446744072635809792
相当于你试图分配那么多内存! 远远超出你的相像. 我在 SSDB 项目里就踩到过几次这种坑! 所以, 记住
小心乘法运算!
建议继续学习:
- 最常见的电话号码 (阅读:2916)
- java中byte转换int时为何与0xff进行与运算 (阅读:2912)
- 整型(int)数字溢出在程序和数据库设计中的考虑 (阅读:2732)
- java中byte转换int时为何与0xff进行与运算 (阅读:2125)
- C语言的整型溢出问题 (阅读:1717)
- 大整数乘法 (阅读:1345)
- Android libcutils库中整数溢出导致的堆破坏漏洞的发现与利用 (阅读:714)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:PHP中字符串截取的效率
后一篇:如何编程实现 2 + 2 = 5? >>
文章信息
- 作者:ideawu 来源: idea's blog
- 标签: int 乘法 溢出
- 发布时间:2014-11-23 21:33:03
建议继续学习
近3天十大热文
- [17] [译]Google Chrome中的高性能网
- [14] 在FreeNAS/BSD搭建基于Nginx+
- [14] 关于Linux的文件系统cache
- [14] 最近总结的一些技巧(vim,python,s
- [13] Linux常用系统信息查看命令
- [11] Linux(Ubuntu 10.04)上安装
- [9] Centos yum 安装nginx+PHP
- [8] PHP加速器 eaccelerator 缓存
- [8] 浏览器缓存机制
- [8] base64_encode 和 urlenc