在AIX上,运行一个多线程程序,然后用truss跟踪,发现有thread_unlock与thread_waitlock_函数,但是使用nm test(程序名)|grep thread_unlock 没有发现该函数,检查相应的加载的动态库中也没有thread_unlock函数,这让我感到很困惑,thread_unlock与thread_waitlock_这些函数从何而来?难道是系统自动添加上的thread_unlock加锁操作?
(ps:makefile没有使用-D_THREAD_SAFE与-lpthread
这是truss的部分记录:
0.0008: thread_waitlock_(0x3000A6C0, 1, 0x00000000) = 1
0.0002: thread_unlock(0x3000A6C0) = 1
0.0001: thread_unlock(0x3000A6C0) = 0
0.0002: thread_waitlock_(0x3000A6C0, 1, 0x00000000) = 1
= 0
0.0001: thread_waitlock_(0x3000A6C0, 1, 0x00000000) = 1
= 1
0.0005: thread_unlock(0x3000A6C0) = 0
)
------解决方案--------------------------------------------------------
这两个函数估计不是应用程序自己直接调用的
很可能是某个系统调用,像进程间同步机制(信号灯啥的)间接调用的
------解决方案--------------------------------------------------------