博客
关于我
(五)GDBdebug调试技术——x86_64架构上参数是如何传递给被调用的函数?
阅读量:399 次
发布时间:2019-03-05

本文共 1014 字,大约阅读时间需要 3 分钟。

函数的参数与调试

在调试过程中,理解函数参数的存储方式对于定位问题至关重要。GDB提供了多种命令来帮助开发者分析函数参数的行为。本文将详细解释如何使用GDB检查与故障相关的函数参数,并展示如何通过调试发现问题。

检查函数参数

在调试过程中,检查函数参数可以帮助缩小有问题的函数范围。以下步骤将指导您如何检查函数参数:

  • 检查函数调用

    代码示例:

    #include 
    #include
    int v1 = 1;float v2 = 0.01;void func(int a, long b, short c, char d, long long e, float f, double g, int *h, float *i, char *j) { printf("a:%d, b:%ld, c:%d, d:%c, e:%lld\n" "f: %.3e, g:3e\nh:%p, i:%p\n,j:%p\n", a, b, c, d, e, f, g, h, i, j);}int main(void) { func(100, 35000L, 5, 'A', 123456789LL, 3.14, 2.99792458e8, &v1, &v2, "sting"); return EXIT_SUCCESS;}
  • 设置断点

    在GDB中设置断点,选择是否加*

    (gdb) b func(gdb) b *func
    • 不加*:断点设置在汇编语言层级的函数开头,无法准确确认某些参数是否保存在栈上。
    • *:断点设置在汇编语言层级的函数开头,确保所有参数都被正确分析。
  • 分析寄存器和栈

    在x86_64架构中,整数和指针参数保存在寄存器中,超过寄存器数量的参数保存在栈中。

    (gdb) x/3g $rsp

    该命令显示栈的内容,包括返回地址和剩余参数。

  • 查看参数值

    使用p命令查看指针和字符串指针的值:

    (gdb) p *(float *)6293952(gdb) p (char *)4196072

    结果显示指针ij指向的值,验证参数传递的正确性。

  • 总结

    通过以上步骤,您可以有效地检查函数参数,确认它们在寄存器和栈中的存储位置。理解这些细节对于定位和修复函数故障至关重要。在实际调试中,结合这些方法可以显著缩小问题范围,提高调试效率。

    转载地址:http://coyzz.baihongyu.com/

    你可能感兴趣的文章
    MySQL 日期时间类型的选择
    查看>>
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>