strace和gdb是Linux环境下的两个常用调试工具,这里是个人在使用过程中对这两个工具常用参数的总结,留作日后查看使用。

strace调试工具

strace工具用于跟踪进程执行时的系统调用和所接收的信号,包括参数、返回值、执行时间。在Linux中,用户程序要访问系统设备,必须由用户态切换到内核态,这是通过系统调用发起并完成的。

strace常用参数:

-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)

strace使用举例:

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文件

gdb调试工具

GDB是GNU开源组织发布的一个强大的UNIX下的程序调试工具。gcc编译时加上-g参数,可以使可执行程序加上gdb调试信息。

(1)info

简写:i,列出gdb子命令的信息,如info break,info variables,info stack等。

(2)list [file:]function

简写:l,查看当前行的上下文,默认为10行,也可以设置在某个函数处列出源码。

(3)edit [file:]function

简写:e,编辑当前所在的行,也可以编辑某个函数的源码。

(4)break [file:]function

简写:b,设置断点,可以设置在某行或某个函数处。

(5)run [arglist]

简写:r,运行程序至断点处停住,run命令之后可以加上调试程序需要的参数。

(6)next

简写:n,单条语句执行。

(7)continue

简写:c,继续运行程序至下一个断点。

(8)print

简写:p,打印变量的值。

(9)bt

查看函数堆栈信息。

(10)enter

回车键,重复上一次调试命令。

(11)help [name]

显示指定的gdb命令的帮助信息。

(12)quit

简写:q,退出gdb。

Linux调试工具strace和gdb常用命令小结的更多相关文章

  1. gdb常用命令小结

    用了这么长时间gdb, 总结下常用用法: http://note.youdao.com/noteshare?id=4a2d1a34624f7197d8e2304c4beb4578

  2. Linux GDB常用命令一栏

    Linux GDB 常用命令如下: 1.启动和退出gdb (1)启动:gdb ***:显示一段版权说明: (*** 表示可执行程序名) (2)退出:quit.有的时候输入quit后会出现相关提示:类似 ...

  3. GDB常用命令使用说明(一)

    本文由霸气的菠萝原创,转载请注明出处:http://www.cnblogs.com/xsln/p/gdb_instructions1.html 全部关于gdb的文章索引请点这里 GDB(GNU Deb ...

  4. Linux的简单介绍和常用命令的介绍

    Linux的简单介绍和常用命令的介绍 本说明以Ubuntu系统为例 Ubuntu系统的安装自行百度,或者参考http://www.cnblogs.com/CoderJYF/p/6091068.html ...

  5. [转]MySQL数据库备份和还原的常用命令小结

    MySQL数据库备份和还原的常用命令小结,学习mysql的朋友可以参考下: 备份MySQL数据库的命令 mysqldump -hhostname -uusername -ppassword datab ...

  6. linux下维护服务器之常用命令

    linux下维护服务器之常用命令! 第1套如下: 正则表达式: 1.如何不要文件中的空白行和注释语句: [root@localhost ~]# grep -v '^$' 文件名 |grep -v '^ ...

  7. gdb常用命令记录

    gdb常用命令 最近在研究nginx源码,gdb用于调试非常方便,之前这篇有研究过如何使用gdb调试nginx:https://www.cnblogs.com/yjf512/archive/2012/ ...

  8. 【Docker】(3)---linux部署Docker、Docker常用命令

    linux部署Docker.Docker常用命令 本次部署Linux版本:CentOS 7.4 64位. 说明: 因为Docker是基于Linux 64bit的 所以Docker要求64位的系统且内核 ...

  9. [转帖]Windows批处理(cmd/bat)常用命令小结

    Windows批处理(cmd/bat)常用命令小结 非常值得学习的文档 先放这里 有时间做实验, 转载自:“趣IT”微信公共号 前言 批处理文件(batch file)包含一系列 DOS命令,通常用于 ...

随机推荐

  1. 【HDU2224】The shortest path(双调欧几里得dp)

    算法导论上一道dp,挺有趣的.于是就研究了一阵. dp(i, j)代表从左边第一个点到第i个点与从从左边最后一个点(即为第一个点)到j点的最优距离和.于是找到了子状态. 决策过程 dp[i][j] = ...

  2. Spring-mvc junit单元测试中 如何回滚?

    @RunWith(SpringJUnit4ClassRunner.class) @WebAppConfiguration(value = "src/main/webapp") @C ...

  3. 多线程面试题(Google)

    有四个线程1.2.3.4.线程1的功能就是输出1,线程2的功能就是输出2,以此类推.........现在有四个文件ABCD.初始都为空.现要让四个文件呈如下格式: A:1 2 3 4 1 2.... ...

  4. Engineer Economic

    1.选择题 10.下列哪项不属于总成本费用() A.生产成本    B.机会成本    C.管理费用    D.财务费用 第1章 11.下列哪项关于自有资金的表述是错误的(D) A.自有资金包括资本金 ...

  5. Java学习笔记——JDBC读取properties属性文件

    Java 中的 properties 文件是一种配置文件,主要用于表达配置信息,文件类型为*.properties,格式为文本文件. 文件的内容是格式是"键=值"(key-valu ...

  6. php 多维数组如何用foreach遍历修改其中的一个值

    数组: array(6) { [0]=> array(11) { ["id"]=> string(2) "76" ["topic_id&q ...

  7. defer和async

    1.decument.wirte不能使用 2.<script src="text.js" type="text/javascript" defer=&qu ...

  8. JQuery原理介绍及学习方法

    前言 对于JQuery,想必大家都很熟悉.目前,很多web项目,在实施的过程中,考虑到各浏览器原生JS API的兼容性,大都会选用JQuery或类似于JQuery这样的框架来进行网页效果开发.JQue ...

  9. 转载:spring ,struct2 在 web.xml中的配置

    转载网址:http://blog.sina.com.cn/s/blog_4c6e822d0102dv63.html <!-- Struts2 need begin-->  <filt ...

  10. php 之 类,对象

    --恢复内容结束--- 一.类和对象: 1.定义: 对象:我们所见到的东西都可以称之为对象,是类实例化出来的东西 类:是对所有的同类对象抽象出来的东西 eg: 在一张表中记录了全班同学的学号,姓名,性 ...