iOS 自旋锁

3 篇文章 0 订阅
1 篇文章 0 订阅

代码混淆马甲包混淆----原文地址:https://blog.csdn.net/u014220518/article/details/95482006

1.OSSpinLock处理效率比synchronized要快很多.如果是频繁操作,推荐使用

模拟一个耗时操作分别加这两种锁  消耗的时间比较一下

- (void)OSSpinLockAndSynchronized{

    OSSpinLock spinLock = OS_SPINLOCK_INIT;

    double_t lastTime = CFAbsoluteTimeGetCurrent();

    for (NSInteger i = 0;i < KRunTimes; i++) {

        OSSpinLockLock(&spinLock);

        OSSpinLockUnlock(&spinLock);

    }

    double_t curTime =  CFAbsoluteTimeGetCurrent();

    NSLog(@"OSSpinLock:%f ms",(curTime - lastTime) * 1000);

    

    //同步

    id obj = [NSObject new];

    lastTime = CFAbsoluteTimeGetCurrent();

    for (NSInteger i = 0; i < KRunTimes; i++) {

        @synchronized (obj) {

            

        }

    }

    curTime = CFAbsoluteTimeGetCurrent();

    NSLog(@"synchroniz:%f ms",(curTime - lastTime) * 1000);

}

2.自旋锁的使用给某一个资源数据块加锁  比如卖票  抢票等资源  如果不加锁的话会造成数据不准确

 

- (void)tickeCountNumbers:(NSInteger)ticketCount

{

    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);

    dispatch_async(queue, ^{

        for (int i = 0; i < 5; i++) {

            [self saleTicket];

            NSLog(@"我是第一个");

        }

    });

    

    dispatch_async(queue, ^{

        for (int i = 0; i < 5; i++) {

            [self saleTicket];

            NSLog(@"我是第二个");

        }

    });

    

    dispatch_async(queue, ^{

        for (int i = 0; i < 5; i++) {

            [self saleTicket];

            NSLog(@"我是第三个");

        }

    });

}

- (void)saleTicket

{

    // 从访问数据之前开始加锁

    

    /* // 初始化锁 (注意加锁,解锁的过程都要为同一把锁才行,不然每次都创建一个新锁,加锁解锁没有意义)

     OSSpinLock lock = OS_SPINLOCK_INIT;如果Lock为局部变量,意味着每次进来这个lock都是新的最好写成一个全局的

    self.lock = lock;

     */

    // 加锁

    NSLog(@"========%p",&_lock);

    OSSpinLockLock(&_lock);

    

    int oldTicketCount = self.ticketsCount;

    sleep(.2);

    oldTicketCount--;

    self.ticketsCount = oldTicketCount;

    NSLog(@"剩余%d票,----%@----",oldTicketCount,[NSThread currentThread]);

    

    // 用完了再解锁

    OSSpinLockUnlock(&_lock);

    

    // 创建了锁,再加锁加锁

}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值