读书人

一个小疑点帮忙看看这个会有什么结果

发布时间: 2013-09-05 16:02:06 作者: rapoo

一个小问题,帮忙看看这个会有什么结果
#include<stdio.h>
#include<string.h>
void main()
{
int x=35;
char str[5];
printf("%d,%d",strlen(str),sizeof(str));
strcpy(str,"this is a good question.");
printf("%d,%d",strlen(str),sizeof(str));
printf("%d,%s",x,str);
}

[解决办法]
char str[5];//在main函数中声明的变量保存在堆栈区
strcpy(str,"thisa");//每次都能正常运行//仅多覆盖了一个字节,还不足以破坏调用main函数对应汇编指令call main时压入堆栈的返回地址。
strcpy(str,"this is a good question.");每次都是段错误////覆盖了19个字节,可能破坏了调用main函数对应汇编指令call main时压入堆栈的返回地址,当main函数返回执行ret指令时,从堆栈中取出垃圾数据并将其装入EIP,导致程序飞到一个不确定处被操作系统发现执行不该执行的内存段或执行非法指令导致段错误。

计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……

对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!

VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。

读书人网 >C语言

热点推荐