iOS 中的NSLock、 NSRecursiveLock、 NSCondition

本文介绍了iOS开发中的三种锁机制:NSLock提供基本的互斥访问,NSRecursiveLock允许递归锁定,而NSCondition用于协调线程间的执行。通过示例展示了如何在多线程环境中使用这些锁来实现并发读写操作,特别是在处理读写锁和GCD屏障(栅栏函数)时的应用,以确保数据一致性并提高性能。
摘要由CSDN通过智能技术生成

iOS中的锁

废话不多说。本篇博客借鉴于《高性能iOS 开发》

NSLock

这是一种低端锁。一旦获取锁,执行则进入临界区,且不会允许超过一个线程并行执行。释放锁则标记临界区结束。

@interface ThreadSafeClass () {
    NSLock *_lock;
}
@end

@implementation ThreadSafeClass

- (instancetype)init
{
    self = [super init];
    if (self) {
        _lock = [NSLock new];
    }
    return self;
}

- (void)threadSafeMethod
{
    [_lock lock];
    
    //threadSafe code
    
    [_lock unlock];
}

@end

NSRecursiveLock 递归锁

递归锁可以被同一线程多次请求,而不会引起死锁。这主要是用在循环或递归操作中
在调用lock之前,NSLock必须先调用unlock。但是递归锁不然,NSRecursiveLock允许在被解锁前锁定多次。如果解锁的次数与锁定的次数相匹配,则认为锁被释放。其他线程可以获取锁。当类中有多个方法使用同一个锁进行同步,且其中一个方法调用另一个方法时,NSRecursiveLock 非常有用。
如下例子

- (instancetype)init
{
    self = [super init];
    if (self) {
        _recursiveLock = [NSRecursiveLock new];
    }
    return self;
}

- (void)threadSafeMethod1
{
    [_recursiveLock lock];
    //threadSafe code
    sleep(2);
    NSLog(@"method 1===%@",_string);
    [self threadSafeMethod2];
    [_recursiveLock unlock];
}

- (void)threadSafeMethod2
{
    [_recursiveLock lock];
//    threadSafe code
    sleep(1);
    NSLog(@"method 2===%@
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值