美文网首页
多线程《线程安全(锁)》_简单了解3

多线程《线程安全(锁)》_简单了解3

作者: 凯司机 | 来源:发表于2022-08-19 20:52 被阅读0次
/// 栅栏函数、线程安全锁
- (void)barrier {
    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
    dispatch_async(queue, ^{
        sleep(2);
        NSLog(@"1");
    });
    dispatch_async(queue, ^{
        NSLog(@"2");
    });
    dispatch_barrier_async(queue, ^{
        NSLog(@"barrier");
    });
    dispatch_async(queue, ^{
        NSLog(@"3");
    });
    dispatch_async(queue, ^{
        NSLog(@"4");
    });
}
/*
执行结果1:
2022-08-21 18:19:24.949868+0800 YDBasicPublicCourse[49563:3947304] 2
2022-08-21 18:19:24.949868+0800 YDBasicPublicCourse[49563:3947306] barrier
2022-08-21 18:19:24.949878+0800 YDBasicPublicCourse[49563:3947308] 3
2022-08-21 18:19:24.950120+0800 YDBasicPublicCourse[49563:3947306] 4
2022-08-21 18:19:26.950422+0800 YDBasicPublicCourse[49563:3947310] 1


执行结果2:
2022-08-21 18:20:27.169850+0800 YDBasicPublicCourse[49573:3949082] barrier
2022-08-21 18:20:27.169850+0800 YDBasicPublicCourse[49573:3949081] 2
2022-08-21 18:20:27.169864+0800 YDBasicPublicCourse[49573:3949085] 3
2022-08-21 18:20:27.170101+0800 YDBasicPublicCourse[49573:3949081] 4
2022-08-21 18:20:29.173572+0800 YDBasicPublicCourse[49573:3949086] 1
*/
// 栅栏函数、线程安全锁_需要自定义队列
- (void)barrier {
    dispatch_queue_t queue = dispatch_queue_create(NULL, DISPATCH_QUEUE_CONCURRENT);
    dispatch_async(queue, ^{
        sleep(2);
        NSLog(@"1");
    });
    dispatch_async(queue, ^{
        NSLog(@"2");
    });
    dispatch_barrier_async(queue, ^{
        NSLog(@"barrier");
    });
    dispatch_async(queue, ^{
        NSLog(@"3");
    });
    dispatch_async(queue, ^{
        NSLog(@"4");
    });
}
/*
执行结果:
2022-08-21 18:21:46.955971+0800 YDBasicPublicCourse[49595:3951260] 2
2022-08-21 18:21:48.956457+0800 YDBasicPublicCourse[49595:3951263] 1
2022-08-21 18:21:48.956695+0800 YDBasicPublicCourse[49595:3951263] barrier
2022-08-21 18:21:48.956841+0800 YDBasicPublicCourse[49595:3951263] 3
2022-08-21 18:21:48.956902+0800 YDBasicPublicCourse[49595:3951261] 4
*/
/// 线程安全:内存的数据被多个线程读写,出现的结果如果是可预见的,锁:保护线程安全——>确保只有一条线程在操作数据
// 互斥锁
- (void)synchronized {
    
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        @synchronized (self) {
            NSLog(@"1");
            sleep(2);
            NSLog(@"1_ok");
        }
    });
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
       //  锁:写法最简单,但是效率最低。
        @synchronized (self) {
            NSLog(@"2");
            sleep(2);
            NSLog(@"2_ok");
        }
    });
}
/*
2022-08-21 18:49:30.473397+0800 YDBasicPublicCourse[49842:3984355] 1
2022-08-21 18:49:32.474201+0800 YDBasicPublicCourse[49842:3984355] 1_ok
2022-08-21 18:49:32.474489+0800 YDBasicPublicCourse[49842:3984345] 2
2022-08-21 18:49:34.478394+0800 YDBasicPublicCourse[49842:3984345] 2_ok
*/
// 信号量:自旋锁
- (void)semaphore {
    dispatch_semaphore_t semaphore = dispatch_semaphore_create(1);
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
        NSLog(@"1");
        sleep(2);
        NSLog(@"1_ok");
        dispatch_semaphore_signal(semaphore);
    });
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
        NSLog(@"2");
        sleep(2);
        NSLog(@"2_ok");
        dispatch_semaphore_signal(semaphore);
    });
}
/*
2022-08-21 18:57:52.967842+0800 YDBasicPublicCourse[49925:3995254] 1
2022-08-21 18:57:54.971486+0800 YDBasicPublicCourse[49925:3995254] 1_ok
2022-08-21 18:57:54.971875+0800 YDBasicPublicCourse[49925:3995253] 2
2022-08-21 18:57:56.972118+0800 YDBasicPublicCourse[49925:3995253] 2_ok
*/
// 信号量:自旋锁
- (void)semaphore {
    // 此处参数为1、是否可以理解为线程数量
    dispatch_semaphore_t semaphore = dispatch_semaphore_create(2);
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
        NSLog(@"1");
        sleep(2);
        NSLog(@"1_ok");
        dispatch_semaphore_signal(semaphore);
    });
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
        NSLog(@"2");
        sleep(2);
        NSLog(@"2_ok");
        dispatch_semaphore_signal(semaphore);
    });
}
/*
2022-08-21 20:38:36.790768+0800 YDBasicPublicCourse[50583:4102255] 2
2022-08-21 20:38:36.790762+0800 YDBasicPublicCourse[50583:4102259] 1
2022-08-21 20:38:38.791510+0800 YDBasicPublicCourse[50583:4102255] 2_ok
2022-08-21 20:38:38.791524+0800 YDBasicPublicCourse[50583:4102259] 1_ok
*/
/*
 semaphore:自旋锁-其他线程正在执行我们锁定的代码,其他线程就会进入死循环等待。
 @synchronized:互斥锁-其他线程正在执行我们的锁定代码,其他线程就会进入休眠。
 **/ 
// 生成一个随机数
- (void)testDispatchApply {
    _number = 0;
    dispatch_apply(10000, dispatch_get_global_queue(0, 0), ^(size_t iteration) {
        self.number++;
    });
    NSLog(@"%d",self.number);
}
/*
2022-08-21 21:20:12.443660+0800 YDBasicPublicCourse[50909:4149925] 6312
*/
// 生成一个随机数_加锁处理《atomic仅在set和get方法里进行加锁处理》
- (void)testDispatchApply {
    _number = 0;
    NSLock *lock = [[NSLock alloc] init];
    dispatch_apply(10000, dispatch_get_global_queue(0, 0), ^(size_t iteration) {
        [lock lock];
        self.number++;
        [lock unlock];
    });
    NSLog(@"%d",self.number);
}
/*
2022-08-21 21:23:44.793507+0800 YDBasicPublicCourse[50947:4154783] 10000
*/
代码块
代码块
代码块

相关文章

  • iOS底层原理 - 多线程原理

    章前回顾 上章我们了解了锁的一些知识,线程安全需要锁的协助。这章我们探索一下多线程原理篇; 初识 周知,了解多线程...

  • iOS底层原理总结 - 多线程的锁

    目录:1.为什么要线程安全2.多线程安全隐患分析3.多线程安全隐患的解决方案4.锁的分类-13种锁4.1.1OSS...

  • 多线程(四)

    上篇多线程(三)我们看了多线程的安全隐患 以及各种锁的简单使用,接下来我们来看看锁的比较、以及自旋锁、互斥锁比较 ...

  • 2018-05-08

    多线程 初级概念与传参 join deatch 原子变量 互斥锁 与 线程安全 线程安全 多线程访问冲突 冲突...

  • 懂这些

    项目整体介绍 1、多线程 线程安全 线程同步 锁 2、内存管理 循环引用,内存泄漏,block 3、性能优化 ...

  • 在 Java 中利用 redis 实现一个分布式锁服务

    在现代的编程语言中,接触过多线程编程的程序员多多少少对锁有一定的了解。简单的说,多线程中的锁就是在多线程环境下,多...

  • 在 Java 中利用 redis 实现一个分布式锁服务

    在现代的编程语言中,接触过多线程编程的程序员多多少少对锁有一定的了解。简单的说,多线程中的锁就是在多线程环境下,多...

  • Java 中利用 redis 实现一个分布式锁服务

    在现代的编程语言中,接触过多线程编程的程序员多多少少对锁有一定的了解。简单的说,多线程中的锁就是在多线程环境下,多...

  • OC--各种线程锁

    参考:正确使用多线程同步锁@synchronized()iOS中的锁iOS多线程安全详解iOS 常见知识点(三):...

  • 条件锁NSConditionLock

    线程锁是什么? 简单来讲,线程锁的存在的就是为了确保数据安全和多线程数据同步。当使用线程A执行一段加锁的代码时,线...

网友评论

      本文标题:多线程《线程安全(锁)》_简单了解3

      本文链接:https://www.haomeiwen.com/subject/epemgrtx.html