【实验练习内容】
将下面的程序输入到一个文件名字为 test.c 的磁盘文件中,利用调试程序找出其中的错误,修改后存盘。该程序的功能是显示一个简单的问候语,然后用反序方式将它列出。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void my_print(char *string);
void my_print2(char *string);
int main()
{
char my_string[] = "hello there";
my_print(my_string);
my_print2(my_string);
}
void my_print(char *string)
{
printf("The string is %s\n", string);
}
void my_print2(char *string)
{
char *string2;
int size, i;
size = strlen(string);
string2 = (char*)malloc(size + 1);
for(i = 0;i < size;i++)
string2[size - i] = string[i];
string2[size+1] = '\0';
printf("The string printed backward is %s\n", string2);
}
【设计参考】
对于给出的程序代码,用下面的命令编译它:
gcc -o test test.c
但是这个会出问题,不改的话后面list出现无法显示问题
改成这个gcc -o test test.c -g
就可以了
末尾加上-g(原因尚未明确)
执行编译得到的程序
./test
显示如下结果:
输出的第一行是正确的,但第二行打印出的东西并不是我们所期望的。我们所设想的输出应该是:
The string printed backward is ereht olleh
由于某些原因,my_print2 函数没有正常工作。让我们用 gdb 看看问题究竟出在哪儿,先键入如
下命令:
gdb test
如果你在输入命令时忘了把要调试的程序作为参数传给 gdb ,你可以在 gdb 提示符下用 file 命令
来载入它:
file test
这个命令将载入 test 可执行文件就象你在 gdb 命令行里装入它一样。
这时你能用 gdb 的 run 命令来运行 test 了:
run
当它在 gdb 里被运行后结果大约会象这样:
蓝框内提示内容
这个输出和在 shell 中运行的结果一样。问题是,为什么反序打印没有工作?为了找出症结所在,我们可以在 my_print2 函数的 for 语句后设一个断点,具体的做法是在 gdb 提示符下键入 list 命令三次,列出源代码:
list
list
list
实际只需要一次就可以,如果list显示效果不行显示这个
(gdb) list 1 <built-in>: 没有那个文件或目录
,在前面的编译的时候
改成gcc -o test test.c -g
然后输入list依次回车就可以了,如下:
只有第一处需要输入list,其余部分直接回车即可,等到回车三次后,输入断点测试即可
根据列出的源程序,你能看到要设断点的地方在第 26
行,在 gdb 命令行提示符下键入如下命令设置
断点:
具体第几行要看自己想设置的断点在哪里,上图要测试的断点在26行,要查看的信息是string2[size - i]对应的变化
break 26
gdb 将作出如下的响应:
再键入 run 命令
能通过设置一个观察 string2[size - i] 变量的值的观察点来看出错误是怎样产生的,做法是键入:
watch string2[size - i]
但是需要注意的是,单纯通过输入上句无法显示更改信息
还需要输入
continue
即可查看,详细见下图:
之后就一直回车就可以了,就可以查看断点的信息
后续的具体分析省略……
改成下面这个程序即可
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void my_print(char *string);
void my_print2(char *string);
int main()
{
char my_string[] = "hello there";
my_print(my_string);
my_print2(my_string);
}
void my_print(char *string)
{
printf("The string is %s\n", string);
}
void my_print2(char *string)
{
char *string2;
int size, size2, i;
size = strlen(string);
size2 = size - 1;
string2 = (char*)malloc(size + 1);
for(i = 0;i < size;i++)
string2[size2 - i] = string[i];
string2[size] = '\0';
printf("The string printed backward is %s\n", string2);
}