linux pthread 互斥锁 读写锁 自旋锁

这篇博客介绍了如何在Linux环境下使用pthread库的互斥锁、读写锁和自旋锁来模拟生产者消费者场景。文章通过具体的代码示例展示了在食物数量约束下,生产者和消费者如何协调工作,并提供了测试方案。
摘要由CSDN通过智能技术生成

1. 概述:
该demo主要实现了linux下通过锁的方式模拟生产者消费者的场景,相关接口介绍可以参考<<UNIX环境高级编程>>
在这里插入图片描述

2. 场景(生产者->消费者):
1)生产者:
当食物数量小于最大值且大于0时, 不断生产食物;
否则当食物为0时,退出线程
2) 消费者:
当食物数量大于0时, 不断消费食物;
否则当食物为0时,退出线程

3. 测试:
在这里插入图片描述

/*
pthread_tip.h
线程锁相关接口介绍 : 互斥锁, 读写锁, 自旋锁

原子性 : 加锁解锁属于原子操作

互斥锁 : 
        非繁忙等待 : 阻塞时不占用cpu资源

读写锁(共享互斥锁) : 
        如果有线程读操作, 则允许其它线程执行读操作, 但不允许写操作
        如果有线程写操作, 则不允许其它线程执行读写操作
        适用于读操作比写操作多得多的情况

自旋锁 : 
        繁忙等待 : 阻塞时占用cpu资源
        适用于锁的持有时间比较短, 或者说小于2次上下文切换时间的情况

*/
#include <pthread.h>
#include <time.h>

/******************************互斥锁*************************************/
//静态初始化, 采用默认的attr
static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;

//动态初始化
int pthread_mutex_init(pthread_mutex_t * mutex, 
                                const pthread_mutexattr_t * attr);

//释放资源
int pthread_mutex_destroy(pthread_mutex_t *mutex);

//请求锁, 如果当前mutex已经被锁, 线程会处于阻塞状态, 直到mutex被释放
int pthread_mutex_lock(pthread_mutex_t *mutex);

//尝试请求锁, 如果当前mutex已经被锁或者不可用, 直接返回失败
int pthread_mutex_trylock(pthread_mutex_t *mutex);

//超时指定愿意等待的绝对时间(与相对时间对比而言, 指定在时间x之前可以阻塞等待, 而不是说愿意阻塞Y秒)
int pthread_mutex_timedlock(pthread_mutex_t * mutex,
                                        const struct timespec * tsptr);

//解锁
int pthread_mutex_unlock(pthread_mutex_t *mutex);


/******************************读写锁*************************************/
static pthread_rwlock_t rwlock = PTHREAD_RWLOCK_INITIALIZER;

int pthread_rwlock_init(pthread_rwlock_t * rwlock, 
                                    const pthread_rwlockattr_t * attr);

int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);

int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock);
int pthread_mutex_timedrdlock(pthread_rwlock_t * rwlock,
                                        const struct timespec * tsptr);

int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);
int pthread_mutex_timedwrlock(pthread_rwlock_t * rwlock,
                                        const struct timespec * tsptr);

int pthread_rwlock_unlock(pthread_rwlock_t *rwlock
在iOS中,可以使用互斥锁来实现线程间的互斥访问,保护共享资源的安全。互斥锁的实现原理可以分为两个层面:内核层面和用户层面。 1. 内核层面的互斥锁实现原理: - POSIX互斥锁:在iOS中,使用POSIX标准的互斥锁pthread_mutex_t来实现。它是基于内核提供的原语实现的,通过系统调用来管理锁的状态。当一个线程请求锁时,如果锁已经被占用,则该线程会被阻塞,并进入等待状态。当持有锁的线程释放锁时,等待队列中的一个线程会被唤醒,获取到锁继续执行。 2. 用户层面的互斥锁实现原理: - 自旋锁自旋锁是一种忙等待的锁机制,它通过循环检查锁的状态,直到获取到锁为止。在iOS中,可以使用OSSpinLock来实现自旋锁。当一个线程请求锁时,如果锁已经被占用,则该线程会一直循环检查锁的状态,直到获取到锁后才继续执行。自旋锁适用于临界区代码执行时间短暂,且争用锁的线程数较少的情况。 - 互斥锁(NSLock、NSRecursiveLock、NSConditionLock):在iOS中,还提供了一些高级的互斥锁类,如NSLock、NSRecursiveLock、NSConditionLock。这些锁类是基于底层的pthread_mutex_t实现的,提供了更方便的API和更高级的功能。NSLock和NSRecursiveLock互斥锁,可以保护临界区代码的互斥访问。NSRecursiveLock允许同一个线程对锁进行多次加锁,避免死锁。NSConditionLock是一种条件锁,可以在特定条件满足时才允许访问临界区代码。 需要注意的是,使用互斥锁时,应遵循良好的加锁和解锁的原则,避免死锁和资源泄漏等问题。同时,在高并发的场景中,也可以考虑使用其他更高级的同步机制,如信号量(dispatch_semaphore)或读写锁(pthread_rwlock_t),以满足不同的需求。 希望以上解答对你有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值