场景:linux上的服务器,功能码写在so里,服务端应用通过dlopen动态加载,服务端是多线程的,测试服务器是虚拟机
gprofile:默认不支持多线程,排除
oprofile:对虚拟机支持不好,不支持计数器接口,但是用时间采样,结果不准
gperf:google的profile工具,也不好用
callgrind:valgrind的工具之一,刚好可以满足需求,valgrind --tool=callgrind --separate-threads=yes 加命令参数。用Ctrl-C停止后,会生成一大堆文件名包含进程ID和线程ID的callgrind文件。这些文件很难看, 在source forge 上有kcachegrind for windows,可以看到函数调用关系和调用次数。
要找到关注的函数在哪个文件,可以用grep命令