Linux终端下调试C语言技巧

系统 Linux
本篇文章向读者介绍了Linux终端下调试C语言的技巧,包括strace、tcpdump、core文件、gdb和log文件的作用。有的还赋给了实例,相信对初学者来说会很有帮助! 、

本篇文章向读者介绍了Linux终端下调试C语言的技巧,包括strace、tcpdump、core文件、gdb和log文件的作用,相信对初学者来说会很有帮助!

1、strace

这个功能很强大,能够看到很多底层调用,便于分析问题:

举例:

[wangbin@localhost pas]$ strace -p 10472
Process 10472 attached - interrupt to quit
futex(0x4113be8, FUTEX_WAIT, 10482, NULL
<unfinished ...>
Process 10472 detached

我们可以看出这个进程已经死锁了,所以strace命令非常有用,特别是网络程序。

2、tcpdump

在分析fastcgi程序时,我们利用这个命令来查看tcp包的情况:

[root@localhost ~]# tcpdump -i lo -s 1500 port 9000
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on lo, link-type EN10MB (Ethernet), capture size 1500 bytes
15:23:16.901004 IP localhost.localdomain.50867 > localhost.localdomain.9000: S 3482201970:3482201970(0) win 32767 <mss 16396,sackOK,timestamp 2296841391 0,nop,wscale 7>
15:23:16.901025 IP localhost.localdomain.9000 > localhost.localdomain.50867: S 3473410857:3473410857(0) ack 3482201971 win 32767 <mss 16396,sackOK,timestamp 2296841391 2296841391,nop,wscale 7>
15:23:16.901039 IP localhost.localdomain.50867 > localhost.localdomain.9000: . ack 1 win 256 <nop,nop,timestamp 2296841391 2296841391>
15:23:16.901150 IP localhost.localdomain.50867 > localhost.localdomain.9000: P 1:1377(1376) ack 1 win 256 <nop,nop,timestamp 2296841391 2296841391>
15:23:16.901170 IP localhost.localdomain.9000 > localhost.localdomain.50867: . ack 1377 win 256 <nop,nop,timestamp 2296841391 2296841391>
15:23:16.901214 IP localhost.localdomain.9000 > localhost.localdomain.50867: P 1:97(96) ack 1377 win 256 <nop,nop,timestamp 2296841391 2296841391>
15:23:16.901222 IP localhost.localdomain.50867 > localhost.localdomain.9000: . ack 97 win 256 <nop,nop,timestamp 2296841391 2296841391>
15:23:16.901236 IP localhost.localdomain.9000 > localhost.localdomain.50867: F 97:97(0) ack 1377 win 256 <nop,nop,timestamp 2296841391 2296841391>
15:23:16.901822 IP localhost.localdomain.50867 > localhost.localdomain.9000: F 1377:1377(0) ack 98 win 256 <nop,nop,timestamp 2296841392 2296841391>
15:23:16.901836 IP localhost.localdomain.9000 > localhost.localdomain.50867: . ack 1378 win 256 <nop,nop,timestamp 2296841392 2296841392>

我们通过这个命令可以发现是9000端口主动关闭了连接,这说明在另一端保持连接是没有效果的。

3、core文件

这个作用就是像取款机旁边的摄像机,能够记录下程序崩溃时的场景,对于分析高难度问题非常有用,不过用这个,一定要权限配置正确了。

4、gdb

gdb -p 进程号,可以去调试正在执行中的进程,功能也很强大。也就是说,只要你上线的程序编译的时候加上了-g,并去掉了优化参数,你就可以在上线的时候调试某一个进程,比如nginx进程。

5、log文件

这是最常用的方法,也是最土的方法,不过对于调试还是非常有用的。

【编辑推荐】

  1. Linux文件分割与合并:split&cat
  2. 推荐:轻型简易的Linux桌面环境
  3. Linux进程与作业的区别及相关命令
  4. Linux下利用ext3grep恢复被删除的文件
  5. Linux十大妙用:充当Windows修复工具

 

责任编辑:冯宇 来源: Linux社区
相关推荐

2009-03-09 21:36:41

Linux终端输出

2014-06-18 10:47:05

dstat监控工具

2018-02-07 15:35:04

2011-01-14 17:00:11

Linux内存泄露

2015-01-27 23:21:53

Linux终端

2020-06-02 14:02:22

Linux生产力工具文件

2015-09-02 10:31:59

UbuntuLinux终端

2016-09-21 08:26:27

LinuxGoogleUbuntu

2018-02-01 17:32:30

LinuxUNIXBash Shell

2021-04-20 09:52:43

Linuxcore dump代码

2020-10-25 16:53:56

Linux 开源操作系统

2018-05-16 11:45:42

Linux终端电池状态

2022-07-18 07:38:52

Linux终端工具

2023-01-03 15:47:09

Linux内核C语言

2015-12-01 13:09:54

Linux终端文件系统

2015-12-03 09:42:56

Linux终端文件系统

2011-08-30 15:41:03

UbuntuNethogs

2019-03-27 11:30:30

Linux终端密码生成器

2020-01-27 10:48:55

Linux终端技巧

2023-02-17 08:14:29

C语言C技巧内存
点赞
收藏

51CTO技术栈公众号