1.博主的实验
这两天把ULK的信号机制和相应的内核源码大致看了一遍,了解到pthread_cond_wait()的底层futex()属于慢系统调用,可以被信号中断,这是导致虚假唤醒的系统层面原因(另一个是逻辑层面)。
所以我就写了一个小demo来进行验证,就是主线程给子线程发信号而已,很简单。结果当然是失败的,不然就不会纠结,也没有这篇记录了。
所以我就很懵逼了,原理上不应该的啊?我想直接去看pthread_cond_wait()的源码,了解到底是怎么回事的… 但是一来不好找对应OS版本的源码,二来是网上广为流传的那段实现,我也看的很懵。。。
#include <stdio.h>
#include <signal.h>
#include <unistd.h>
#include <errno.h>
#include <pthread.h>
pthread_cond_t cond;
pthread_mutex_t mutex;
int condTest = 1;
void handler(int s)
{
printf("Wati is interrupt by signal handler\n");
return;
}
void* testFunc(void* data)
{
struct sigaction act;
act.sa_handler

博主通过实验发现,pthread_cond_wait()的虚假唤醒现象在不同Unix系统中表现不一,Linux环境下难以复现。尽管信号可能导致中断,但实验结果并未如预期。在StackOverflow上找到类似问题,指出在Solaris上该函数会返回EINTR,而Linux(如CentOS7)行为未明。对于如何编写跨平台的代码以应对这种情况,仍需深入理解不同内核的实现。
最低0.47元/天 解锁文章

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



