队列,异步,同步,线程通俗理解

2020-01-14  本文已影响0人  qjsxq

一、队列

串行队列

并行队列

主队列(只在主线程执行的串行队列)

全局队列(系统的并行队列)

二、 任务(是否具有开启线程的能力)

同步任务(不具备开启线程的能力)

异步任务(具备开启线程的能力)

三 、用车站买票表示整个流程

1、窗口代表线程

image

2、有3个旅行团,排队的方式表示队列

并排排队 表示 并行队列

image

排成一行表示串行队列

image

四、分情况讨论

1、串行队列 + 同步执行

因为同步执行所以没有开启线程,买票表示为只有一个主窗口1(主线程)开放,所有人排成一个长排在窗口1(表示主线程)买票如下图

image

2、串行队列 + 异步执行

因为是异步所以具有开启子线程的能力,表示其他窗口也开放队伍在一个不是主窗口的窗口(子线程)排成一排买票

image

3、并行队列 + 同步执行

因为是同步所以不具备开启子线程,买票为所有旅行团一起排到主窗口买票

image

 // 全局并行队列

    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);

    // 同步任务

    dispatch_sync(queue, ^{

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

            NSLog(@"A%d买票---%@",i +1,[NSThreadcurrentThread]);

        }

    });

     // 同步任务

    dispatch_sync(queue, ^{

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

            NSLog(@"B%d买票---%@",i +1,[NSThreadcurrentThread]);

        }

    });

     // 同步任务

    dispatch_sync(queue, ^{

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

            NSLog(@"C%d买票---%@",i +1,[NSThreadcurrentThread]);

        }

    });

因为队列是先进先出,所以是A团队一个接着一个买完之后,B团队买,最后是C团队


**2020-01-14 14:23:11.608452+0800 Interview-01[77999:3550518] A1买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.608621+0800 Interview-01[77999:3550518] A2买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.608727+0800 Interview-01[77999:3550518] A3买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.608831+0800 Interview-01[77999:3550518] A4买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.608949+0800 Interview-01[77999:3550518] A5买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.609053+0800 Interview-01[77999:3550518] B1买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.609201+0800 Interview-01[77999:3550518] B2买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.609321+0800 Interview-01[77999:3550518] B3买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.609422+0800 Interview-01[77999:3550518] B4买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.609589+0800 Interview-01[77999:3550518] B5买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.609927+0800 Interview-01[77999:3550518] C1买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.610166+0800 Interview-01[77999:3550518] C2买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.610378+0800 Interview-01[77999:3550518] C3买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.614587+0800 Interview-01[77999:3550518] C4买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

**2020-01-14 14:23:11.614724+0800 Interview-01[77999:3550518] C5买票---<NSThread: 0x600001ee5380>{number = 1, name = main}**

4 、并行队列 + 异步执行

并行队列可以同时执行,异步具有开启子线程的能力,用买票表示为3个团队分别在不同的子窗口(子线程)买票 ,3个窗口同时买票

image

5、主队列 + 同步异步任务

主队列是串行队列,但是主队列里的任务只能在主线程执行,所以当主队列+ 异步任务是,虽然异步具有开启线程的能力,但是任务还是在主线程执行。买票来说,就是只能排在主窗口。

主队列加同步任务会造成死锁。


- (void)viewDidLoad {

    [super viewDidLoad];

    // 全局并行队列

    dispatch_queue_t queue = dispatch_get_main_queue();

    // 同步任务

    dispatch_sync(queue, ^{

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

            NSLog(@"A%d买票---%@",i +1,[NSThreadcurrentThread]);

        }

    });

}

如上面的代码,因为同步任务加入到队列中要立即执行,但是viewDidLoad又是先加入的主队列中的,根据队列的先进先出,又要viewDidLoad执行完之后才能执行买票任务。所以就造成的互相等待,死锁。

上一篇 下一篇

猜你喜欢

热点阅读