如何在Linux上监视多线程(pthread)C++程序的每个线程行为

How to monitor each thread behavior of a multithread (pthread) C++ program on Linux ?

本文关键字:程序 C++ 线程 pthread Linux 监视 多线程      更新时间:2023-10-16

我正在Linux(redhat)上运行一个多线程(pthread)C++程序。

我想遵循正在运行的程序的行为,但线程的打印输出会相互交错。很难找出每个线程的行为。

我想使用DDD(一个gdb GUI)来分析程序的行为,但它需要"motif",当我安装"motive"时,它有一个错误:

cc-c-O-I.//包括-I.//导入/x11/include/x11 ./ccimake imake.cimake.c:162:21:错误:Xosdefs.h:没有这样的文件或目录

我也使用了helgrind和drd工具,但有很多纯文本打印出来,这让它混淆了每个线程的行为。

你能推荐更好的开源工具吗?这些工具可以帮助我清晰方便地调试和分析/监控多个pthread的行为?

是否可以在不同的终端xterm窗口中显示每个线程,而不将所有线程混合在一起?

感谢

像printf这样的标准打印函数不是线程安全的。如果您要记录到stdout或单个文件,则需要将日志记录函数视为关键部分,并使用互斥锁来保护它们。否则,您的日志可能会交错或出现故障。

或者,您可以让每个线程创建自己的日志文件,将线程名称/id和时间戳写入每个文件,并在单独的终端中"跟踪"这些日志文件。

  • 一定要使用printf进行打印,这样至少行会完整打印
  • 确保每个线程都使用前缀,如[MainThread] Log message...
  • 直接输出到文件:your_program > logfile.txt
  • 对于每个线程,执行:tail -f logfile.txt | grep <thread_prefix>