Linux_线程同步_自旋锁

自旋锁pthread_spinlock_t

和互斥锁类似,只是当加锁操作被阻塞,阻塞的方式不同:互斥锁是通过将线程睡眠,自旋锁则是通过忙等待的方式,不断判断锁是否能够被成功获取。

自旋锁一般适用的场景是锁被其他线程短期持有(很快会被释放),而且等待该锁的线程不希望在阻塞期间被取消调度,因为这会带来一些开销,因此操作系统的内核经常使用自旋锁。如果自旋执行时间太长,会有大量的线程处于自旋状态占用CPU资源,进而会影响整体系统的性能,因此可以给自旋锁设定一个自旋时间,等时间一到立即释放自旋锁。

自旋锁不会使线程状态发生切换,一直处于用户态,即线程一直都是active的;不会使线程进入阻塞状态,减少了不必要的上下文切换,执行速度快。

初始化:

int pthread_spin_init(pthread_spinlock_t *lock, int pshared);

pshared 是一个标志,表示这个自旋锁是否应该被多个进程共享。如果这个自旋锁只在一个进程的线程之间共享,应该设置为 PTHREAD_PROCESS_PRIVATE;如果在多个进程间共享,设置为 PTHREAD_PROCESS_SHARED。
函数成功时返回 0,否则返回一个错误码。

销毁:

int pthread_spin_destroy(pthread_spinlock_t *lock);
函数成功时返回 0,否则返回一个错误码。

加锁:

int pthread_spin_lock(pthread_spinlock_t *lock);

int pthread_spin_trylock(pthread_spinlock_t *lock);
如果自旋锁已经被占有,返回EBUSY,不会等待,其他错误返回相应错误码。

解锁:

int pthread_spin_unlock(pthread_spinlock_t *lock);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值