背景
信号量的使用在上一节中已经说明,想了解细节的小伙伴跳转一下。在实际工程中,有两个线程A和B,如果A一直等待B的同步信号,则导致A的任务无法继续执行,若B挂死,则A的其他业务也受影响,所以,为了避免这种情况,需要对B的信号量做一个超时机制,那就不能使用sem_wait函数了,可以使用sem_timedwait函数还获取B的信号量,若超时,则退出等待,继续运行其他的业务逻辑。
demo
#include <stdio.h>
#include <semaphore.h>
#include <time.h>
#define TIMEOUT_SECONDS 5
int main()
{
sem_t sem;
int ret;
// 初始化一个信号量,初始值为 0
ret = sem_init(&sem, 0, 0);
if (ret != 0) {
perror("sem_init failed");
return -1;
}
printf("Main thread: Waiting for the semaphore ...\n");
// 等待信号量超时
struct timespec timeout;
clock_gettime(CLOCK_REALTIME, &timeout);
timeout.tv_sec += TIMEOUT_SECONDS;
本文介绍了在C++和Linux环境下,如何为线程同步的信号量设置超时机制。通过示例代码(demo)展示了当线程A等待线程B的同步信号时,如果使用sem_timedwait函数,当超过设定时间B未发送信号,线程A将不再等待,继续执行其他业务,避免了任务阻塞的问题。
订阅专栏 解锁全文
8543

被折叠的 条评论
为什么被折叠?



