我一直在用mutrace分析我的代码并且有以下有趣/令人担忧的结果:
Mutex #1260690 (0x0x7f87bc8eea40) first referenced by:
/usr/lib/mutrace/libmutrace.so(pthread_mutex_lock+0x49) [0x7f87be0b76b9]
/lib/x86_64-linux-gnu/libgcc_s.so.1(_Unwind_Find_FDE+0x26) [0x7f87bc6eb0e6]
mutrace: Showing 10 most contended mutexes:
Mutex # Locked Changed Cont. tot.Time[ms] avg.Time[ms] max.Time[ms] Flags
1260690 19066789 1509831 109753 3600.883 0.000 0.226 M-.--.
Run Code Online (Sandbox Code Playgroud)
在_Unwind_Find_FDE似乎要处理堆栈展开.
我的应用程序是高度多线程的,具有非常严格的延迟要求,所以我想尽可能简单地消除它.是否有任何编译器或环境设置我可以用来摆脱这个函数调用,而不重写我的代码?我们确实对流控制的一部分使用异常(可能是不明智的)但是修复它是一个很大的重构工作.
g++ (Ubuntu 4.8.2-19ubuntu1) 4.8.2
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
563 次 |
| 最近记录: |