这篇只是记录自己的不小心,下次别再犯同样的错误。
手工tags: GDB step define 宏定义
今天发现某一个函数的结果极其奇怪,正好最近在学用GDB,就用GDB调试一下。
(gdb) n
11 amic_list_append(list, ptr);
(gdb) s
13 printf("[%s]\n", (char *)list->first->data);
step并不能够跳进去函数中,而是直接跳出。
网上查找了一下原因,编译该函数时,若没有加上-g选项则不能跳进去。
(事后实验了下,不加-g跳不进去的现象和我这次的现象一样)
但makefile后发现,没有漏掉-g。 那么,会是什么原因呢?
自己先写了一个小的demo,在调试demo时发现可以跳进去。那说明函数没有问题,问题是出在了调用方。
可调用方的错误会在哪呢,找了半天也没有找出来,就算不能调试问题也得解决,所以就用了自己打日志的老办法。
在amic_list_append函数内部,将参数信息输出到stderr。
编译运行,该条信息根本就没有输出。也就是说,程序就没有走到这个函数里面去。
难道是没有现实这个函数? nm下函数所在的.o文件,存在amic_list_append.
.o中已经实现了该函数,但为什么调用不到这个函数呢?
这调用方这是白纸黑字的调用了amic_list_append的。
那么原因就可能是调用的函数并不是预想的函数,可能是函数重