源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

基于Linux调试工具strace与gdb的常用命令总结

  • 时间:2022-12-27 23:05 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:基于Linux调试工具strace与gdb的常用命令总结
strace和gdb是Linux环境下的两个常用调试工具,这里是个人在使用过程中对这两个工具常用参数的总结,留作日后查看使用。 [b]strace调试工具 [/b]strace工具用于跟踪进程执行时的系统调用和所接收的信号,包括参数、返回值、执行时间。在Linux中,用户程序要访问系统设备,必须由用户态切换到内核态,这是通过系统调用发起并完成的。 [b]strace常用参数: [/b]-c  统计每种系统调用执行的时间、调用次数、出错次数,程序退出时给出报告 -p pid  跟踪指定的进程,可以使用多个-p同时跟踪多个进程 -o filename  strace默认输出到stdout,-o可以将输出写入到指定的文件 -f  跟踪由fork产生的子进程的系统调用 -ff  常与-o选项一起使用,不同进程(子进程)产生的系统调用输出到各个filename.pid文件中 -F  尝试跟踪vfork子进程系统调用,注意:与-f同时使用时, vfork不被跟踪 -e expr  输出过滤表达式,可以过滤掉不想输出的strace结果 -e trace=set  指定跟踪set中的系统调用 -e trace=network  跟踪与网络有关的所有系统调用 -e strace=signal  跟踪所有与系统信号有关的系统调用 -e trace=ipc  跟踪所有与进程通讯有关的系统调用 -e signal=set  指定跟踪set中的信号 -e read=set  输出从指定文件中读出的数据,例如-e read=3,5 -e write=set  输出写入到指定文件中的数据,例如-e write=1 -r  打印每一个系统调用的相对时间 -t  在输出中的每一行前加上时间信息 -tt  在输出中的每一行前加上时间信息,时间精确到微秒级 -ttt  在输出中的每一行前加上时间信息,输出为相对时间 -s  指定每一行输出字符串的长度(默认为32) [b]strace使用举例: [/b]strace -t whoami  #跟踪whoami可执行程序,每行输出结果前打印执行的时间 strace -p 17151 -p 17152 -p 17153  #同时跟踪进程17151、17152、17153 strace -f -e trace=read,write -p 17151 -o log  #跟踪进程17151及子进程中read和write系统调用,输出到log文件 [b]gdb调试工具 [/b]GDB是GNU开源组织发布的一个强大的UNIX下的程序调试工具。gcc编译时加上-g参数,可以使可执行程序加上gdb调试信息。 [b](1)info [/b]简写:i,列出gdb子命令的信息,如info break,info variables,info stack等。 [b](2)list [file:]function [/b]简写:l,查看当前行的上下文,默认为10行,也可以设置在某个函数处列出源码。 [b](3)edit [file:]function [/b]简写:e,编辑当前所在的行,也可以编辑某个函数的源码。 [b](4)break [file:]function [/b]简写:b,设置断点,可以设置在某行或某个函数处。 [b](5)run [arglist] [/b]简写:r,运行程序至断点处停住,run命令之后可以加上调试程序需要的参数。 [b](6)next [/b]简写:n,单条语句执行。 [b](7)continue [/b]简写:c,继续运行程序至下一个断点。 [b](8)print [/b]简写:p,打印变量的值。 [b](9)bt [/b]查看函数堆栈信息。 [b](10)enter [/b]回车键,重复上一次调试命令。 [b](11)help [name] [/b]显示指定的gdb命令的帮助信息。 [b](12)quit [/b]简写:q,退出gdb。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部