os_unfair_lock pthread_mutex

OSSpinLock

OSSpinLock叫做"自旋锁",等待锁的线程会处于忙等busy-wait状态.一直占用着CPU资源.目前已经不再安全,可能出现优先级反转问题.如果等待锁的线程优先级较高,它会一直占用者CPU资源,优先级低的线程就无法释放锁.OC中需要导入头文件#import <libkern/OSAtomic.h>.Swift中不需要导入.使用os_unfair_lock替代OSSpinLock.

class HomeViewController: UIViewController {
    //不能使用let,因为加锁解锁要改变锁的状态,
    //需要使用变量var
    var lock = os_unfair_lock()
    override func viewDidLoad() {
        super.viewDidLoad()
        
        //尝试加锁
        if os_unfair_lock_trylock(&lock) {
            //加锁
            os_unfair_lock_lock(&lock)
            //如果业务代码有可能提前退出,使用defer
            //用来定义以任何方式(抛错误,return等)离开代码快
            //前必须要执行的代码
            defer {
             //解锁
            os_unfair_lock_unlock(&lock)
                    
            }
            //业务代码
            /*
                有可能抛出异常 非正常退出
             */
        }
    }

pthread_mutex_t

class HomeViewController: UIViewController {
    var mutex: pthread_mutex_t = {
        //初始化锁属性
        var mutexattr = pthread_mutexattr_t()
        //锁属性赋值
        pthread_mutexattr_settype(&mutexattr, PTHREAD_MUTEX_DEFAULT)
        //初始化锁
        var mutex = pthread_mutex_t()
        
        //pthread_mutex_init(&mutex, nil)
        //mutexattr传nil表示default
        pthread_mutex_init(&mutex, &mutexattr)
        //使用锁属性之后要释放
        pthread_mutexattr_destroy(&mutexattr)
        //返回锁
        return mutex
    }()
    /*锁属性
     Mutex type attributes
     DEFAULTe和NORMAL两种属性相同,意为初始化一把普通的锁
     PTHREAD_MUTEX_RECURSIVE:递归所
     PTHREAD_MUTEX_ERRORCHECK:x检查错误的锁
     public var PTHREAD_MUTEX_NORMAL: Int32 { get }
     public var PTHREAD_MUTEX_ERRORCHECK: Int32 { get }
     public var PTHREAD_MUTEX_RECURSIVE: Int32 { get }
     public var PTHREAD_MUTEX_DEFAULT: Int32 { get }
     */
    override func viewDidLoad() {
        super.viewDidLoad()
         //加锁
        pthread_mutex_lock(&mutex)
        
        //业务加锁代码
        
        //解锁
        pthread_mutex_unlock(&mutex)
//      defer {
//            pthread_mutex_unlock(&mutex)
//      }
    }
    
    deinit {
        //释放锁
        pthread_mutex_destroy(&mutex)
    }  
}

递归锁

递归锁:允许同一个线程多次加锁,不同线程进入加锁入口,会处于等待状态,需要等待上一个线程解锁完成 才能进入加锁状态.

176.10分

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 多线程的安全隐患 在使用多线程的过程中,一块资源可能会被多个线程共享,也就是多个线程可能会访问同一块资源,同一个变...
    雪山飞狐_91ae阅读 3,952评论 0 1
  • 前言   在使用多线程的时候多个线程可能会访问同一块资源,这样就很容易引发数据错乱和数据安全等问题。解决资源争用,...
    小盟城主阅读 5,237评论 0 3
  • 转发:LockForiOS 又到了春天挪坑的季节,想起多次被问及到锁的概念,决定好好总结一番。 翻看目前关于 iO...
    Cooci_和谐学习_不急不躁阅读 6,689评论 1 22
  • 你理解的多线程? iOS的多线程方案有哪几种?你更倾向于哪一种? pthread 􏼑􏴓􏴔跨平台 、使用难度大,手动...
    英雄出少年阅读 2,629评论 0 0
  • 前言:本文简述多线程相关内容,如有错误请留言指正。 Q:多线程的几种方案? pthread一套通用的多线程API适...
    梦蕊dream阅读 4,046评论 1 2