蓝森林首页 | 返回主页 | 本站地图 | 站内搜索 | 联系信箱 |
 您目前的位置:首页 > 自由软件 > 技术交流 > 应用编程


    

蓝森林 http://www.lslnet.com 2006年6月6日 10:18


【提问】缓冲区溢出,为什么不是一溢出就出错?

[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”?

在我的 linux下 第9个就 segmentation falut 了

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

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

-->


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

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

我也这样认为



Copyright © 1999-2000 LSLNET.COM. All rights reserved. 蓝森林网站 版权所有。 E-mail : webmaster@lslnet.com