先看看libco例子中的example_cond.cpp的生产者
void* Producer(void* args)
{
co_enable_hook_sys();
stEnv_t* env= (stEnv_t*)args;
int id = 0;
while (true)
{
stTask_t* task = (stTask_t*)calloc(1, sizeof(stTask_t));
task->id = id++;
env->task_queue.push(task);
printf("%s:%d produce task %d\n", __func__, __LINE__, task->id);
co_cond_signal(env->cond);
poll(NULL, 0, 1000);
}
return NULL;
}
其中,第一个函数就要使能hook,而hook是一个什么东西呢?
hook说白了,就是比如本来你调用了socket(),这个函数,现在你使用一种方式,让程序运行时,先调用socket这个函数时,实际是调用了你写的另一个函数,看看是怎么实现的。
#define HOOK_SYS_FUNC(name)\
if( !g_sys_##name##_func ) \
{ \
g_sys_##name##_func = (name##_pfn_t)dlsym(RTLD_NEXT,#name); \
}
假设我们hook socket函数,其展开应该是如下
if (!g_sys_socket_func)
{
g_sys_socket_func = (socket_pfn_t)dlsym(RTLD_NEXT, "socket");
}
这就说明必须有定义了一个函数指针g_sys_socket_func,