pthread spinlock 有坑

spinlock 在某些情况下比mutex慢很多

先上代码

// spinlock.c
#include <stdio.h>
#include <pthread.h>
#include <stdlib.h>
 
static int count = 0;
static pthread_spinlock_t spinlock;
 
void *test_func(void *arg)
{
        int i=0;
        for(i=0;i<100000;++i){
                pthread_spin_lock (&spinlock);
                count++;
                pthread_spin_unlock(&spinlock);
        }
        return NULL;
}
 
int main(int argc, const char *argv[])
{
        pthread_t id[100];
        int i = 0;
        pthread_spin_init (&spinlock, 0);
 
        for(i=0;i<100;++i){
                pthread_create(&id[i],NULL,test_func,NULL);
        }
 
        for(i=0;i<100;++i){
                pthread_join(id[i],NULL);
        }
 
        printf("%d\n",count);
        return 0;
}

这是我网上找的spinlock 测试代码,在我2核的centos台式机上执行时间是:

real 0m8.758s
user 0m17.305s
sys 0m0.003s

这比用mutex慢太多。

我想到的原因:
由于pthread_spin_lock 碰撞的时候将调用线程进入忙等待而浪费大量CPU,如果全部线程都在忙等待而不让出CPU的话,其他线程就没有机会执行了。
这在线程数远超CPU核数的情况下尤其明显。

spinlock 一般情况会比mutex快很多,但是使用起来确实要很小心,一不小心就掉坑里了。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值