【INT的内核笔记】关于pthread_cond_wait()虚假唤醒,在不同unix系内核的实验结果

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_handl
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值