免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1301 | 回复: 3
打印 上一主题 下一主题

【提问】缓冲区溢出,为什么不是一溢出就出错? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-05-25 22:55 |只看该作者 |倒序浏览
[mhung@mybsd ~]$ cat buf.c
#include <stdio.h>

int
main()
{
     char  buf       [5];

     printf("Enter your first name:");
     scanf("%s", buf);
     printf("%s\n", buf);
}
[mhung@mybsd ~]$
[mhung@mybsd ~]$ gcc -o buf buf.c
[mhung@mybsd ~]$
[mhung@mybsd ~]$
[mhung@mybsd ~]$ perl -e 'print "a" x 27'|./buf
Enter your first name:aaaaaaaaaaaaaaaaaaaaaaaaaaa

[mhung@mybsd ~]$ perl -e 'print "a" x 28'|./buf
Enter your first name:aaaaaaaaaaaaaaaaaaaaaaaaaaaa
Segmentation fault: 11 (core dumped)
[mhung@mybsd ~]$
[mhung@mybsd ~]$ gcc --version
gcc (GCC) 3.4.4 [FreeBSD] 20050518
Copyright (C) 2004 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

[mhung@mybsd ~]$

buf最多4个字符(最5个是\0),为什么等到28个字符才报错“segmentation fault”?

论坛徽章:
0
2 [报告]
发表于 2006-05-25 23:40 |只看该作者
在我的 linux下 第9个就 segmentation falut 了

系统不同,产生结果不同。

但最主要的原因是,gcc 要预留一些空间用来边界对齐作用,所以不一定是5个就 falut 了

论坛徽章:
0
3 [报告]
发表于 2006-05-26 00:10 |只看该作者
原帖由 mik 于 2006-5-25 23:40 发表
在我的 linux下 第9个就 segmentation falut 了

系统不同,产生结果不同。

但最主要的原因是,gcc 要预留一些空间用来边界对齐作用,所以不一定是5个就 falut 了



5个byte空间被填充后,4个byte将返回地址填充了。故出现segmentation fault

论坛徽章:
0
4 [报告]
发表于 2006-05-26 09:02 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP