我已经完成了对条件变量的阅读,但我只是无法理解如何使用它们。
我有一棵树,到目前为止,当您为已经存在的节点进行插入时,它返回 0,这意味着它已经存在因此失败。
我现在想扩展 pthreads 支持,而不是提到它因为它已经存在并返回 0 而无法完成,我希望它位于等待队列中,一旦请求的节点被删除,继续现在插入。
例如,
假设一棵树有 3 个节点,值为 1、5、10 如果我想插入一个值为 10 的新节点,而不是返回 0 并抛出该值已存在的错误,它应该等待值为 10 的节点要删除,一旦删除,它应该返回并插入。
我的插入函数 else 块,它在之前检查过该节点是否存在该值后返回 0,您可以放心,知道它存在的逻辑工作正常,现在我只是尝试在它等待的地方添加条件变量支持. 数据字段条件在插入的第一行初始化,所以也完成了。我现在希望当它进入这个块时, cond_wait 是唯一将被执行的代码行,然后它会简单地等到 delete 发出信号。我的方法在这里正确吗?如果是,在删除中,我该如何发出信号?请在这里帮助我,我花了几个小时阅读和查看示例以试图解决这个问题。
代码,
else
{
//IF DUPLICATE EXISTS
pthread_mutex_lock(&m);
node->counter++;
pthread_cond_wait(&node->condition, &m);
_insert(string, strlen, ip4_address, node, NULL, NULL);
pthread_mutex_unlock(&m);
return 1;//I CHANGED IT FROM 0 to one, since if signalled, and if reached to this limit
//it was probably successful
}