gdb call 函数调用

在 gdb 里可以用 call 命令来调用函数,跟代码里调用效果是一样的。在任一断点处都可以用 call 来调用函数,但不知是否需要debug 信息来支持,我这里实际操作的都是带debug信息的程序。首先打一个断点,如:

当断点触发时,我们可以用 call function 来看一个这个函数的原型,如:

其实如果我们要用call 来调用函数,我们是应该先知道该函数原型的,且知道函数的作用的,同时了解哪人是入参,哪个是出参。所以我要调用这个函数时,因为有两个指针参数,我打断点的这个函数里也没有可以直接用的变量,所以用 call malloc 来申请内存变量,如:

申请的内存变量为 $12,具体申请的大小,根据结构体参数大小而定。因为入参需要有数据,所以这里就需要强制转换,并且赋值。而出参也是需要一个指针变量的,所以也申请了一个临时变量:

申请的出参变量的大小也是根据结构体变量来定,可以申请比期望的大,如 call malloc(128) ,其实我只需要 24 字节。申请成功后,直接调用,返回值为 0 表示函数执行成功了,同时出参 $13 里保存了想要的数据,然后就可以转换成结构体查看数据内容了。

相关推荐
故事还在继续吗12 天前
常见的导致 coredump 的原因
开发语言·gdb
C咖咖15 天前
Linux 下使用 GDB 调试 C++ 的全面总结
linux·gdb·调试
lightqjx24 天前
【Linux】Linux工具(yum、vim、gcc/g++、make/makefile、gdb)的详细介绍
linux·vim·gdb·yum·gcc/g++·linux工具·make/makefile
爱凤的小光24 天前
GDB调试技巧与指令完全指南---个人学习篇
shell·gdb
kali-Myon1 个月前
CTFshow-Pwn142-Off-by-One(堆块重叠)
c语言·数据结构·安全·gdb·pwn·ctf·
花花少年1 个月前
在嵌入式设备中快速体验gdb调试
gdb
Qt程序员2 个月前
深入理解:GDB调试器的工作原理
linux·c++·gdb·调试器
十年编程老舅2 个月前
Linux GDB 调试超详细教程:入门 + 实战
linux·c++·gdb
Lucis__3 个月前
版本控制器git及gdb调试技巧深度剖析
git·gdb·开发工具
彭泽布衣4 个月前
gdb调试方法总结
linux·c语言·gdb·故障排查·段错误