一、队列
串行队列
并行队列
主队列(只在主线程执行的串行队列)
全局队列(系统的并行队列)
二、 任务(是否具有开启线程的能力)
同步任务(不具备开启线程的能力)
异步任务(具备开启线程的能力)
三 、用车站买票表示整个流程
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执行完之后才能执行买票任务。所以就造成的互相等待,死锁。