ios多线程操作(四)—— GCD核心概念


GCD全称Grand Central Dispatch。可译为“大派发中枢调度器”,以纯C语言写成,提供了很多很强大的函数。GCD是苹果公司为多核的并行运算提出的解决方式,它能够自己主动利用很多其它的CPU内核来參与运算。会自己主动管理线程的生命周(创建线程、调度任务、销毁线程)。而程序猿仅仅须要告诉GCD想要运行什么任务,不须要编写不论什么线程管理代码!

     GCD中有两个核心概念,一是任务。二是队列。
     任务:要运行什么样的操作。任务都是预先以Block封装好准备要运行的一段代码。
     队列:用来存放任务,依照先进先出的方式,调度任务在哪一条线程上运行。
     GCD中有两个用来运行任务的函数,各自是同步函数和异步函数。

     同步函数:该函数的代码形式例如以下
dispatch_sync(dispatch_queue_t queue, ^(void)block)
  当中queue为队列,block为任务
  同步任务并不会创建线程,但会在当前线程(能够是子线程,页能够是主线程)中运行。同步任务有一个特性。仅仅要同步任务一加入到队列中就要立即运行。同步任务不运行完就不会运行往后的代码。

比如:
- (void)viewDidLoad {
    [super viewDidLoad];
    // 获得全局队列
    dispatch_queue_t q = dispatch_get_global_queue(0, 0);
    // 运行同步任务
    dispatch_sync(q, ^{
        // 让运行该任务的线程休眠2s
        [NSThread sleepForTimeInterval:2.0];
        NSLog(@"block - %@",[NSThread currentThread]);
    });
    NSLog(@"viewDidLoad - %@",[NSThread currentThread]);
}

执行结果例如以下:


据此能够验证同步任务的特性

  异步函数:
dispatch_async(dispatch_queue_t queue, ^(void)block)
  普通情况下异步任务都会开启一条子线程在后台运行(有一种情况除外。后面会讲到),异步任务的一个特性就是不用等待当前线程的任务就能直接运行
比如:
- (void)viewDidLoad {
    [super viewDidLoad];
    // 获得全局队列
    dispatch_queue_t q = dispatch_get_global_queue(0, 0);
    // 运行异步任务
    dispatch_async(q, ^{
        //
        for (int i = 0; i<10; i++) {
            NSLog(@"block - %@ - %d",[NSThread currentThread],i);
        }
    });
    NSLog(@"viewDidLoad - %@",[NSThread currentThread]);
}

执行结果例如以下:


第二次执行结果:

能够看到两次执行结果不同,且不在同一线程中.
假设将代码改为例如以下形式:
- (void)viewDidLoad {
    [superviewDidLoad];
    //获得全局队列
    dispatch_queue_t q =dispatch_get_global_queue(0, 0);
    //运行异步任务
    for (int i = 0; i< 10; i++) {
        dispatch_async(q, ^{
            NSLog(@"block - %@ - %d",[NSThreadcurrentThread],i);
        });
        
    }
    NSLog(@"viewDidLoad - %@",[NSThreadcurrentThread]);
}

运行结果例如以下:

由此可得队列开启多少条我们无法控制。异步函数并不会等待当前线程(当前线程为主线程)的任务。

原文地址:https://www.cnblogs.com/clnchanpin/p/6809010.html