如何在Linux上监视多线程(pthread)C++程序的每个线程行为
How to monitor each thread behavior of a multithread (pthread) C++ program on Linux ?
我正在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>
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- C++,系统无法执行指定的程序
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到
- 重载操作程序时出错>>用于类中的字符串 memebr
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 试图在visual studio上用C++创建一个桌面应用程序
- 模板元程序查找相似的连续类型名称
- FFmpeg:制作一个应用程序比直接使用ffmepg更好吗
- 如何通过cpp程序运行shell脚本
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- IPC使用多个管道和分支进程来运行Python程序
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 基于boost的程序的静态链接——zlib问题
- 程序崩溃并显示"std::out_of_range"错误
- 在C应用程序中运行C++(带有STL)函数
- 使用mongocxx驱动程序时包含头文件问题
- 如何在c++程序中找到函数的地址