直接贴测试代码了。
当前考虑的问题:
1.队列有多少个消费者
2.添加到队列的新task是同步运行(当前线程阻塞)还是异步(当前线程不阻塞)
3.多个队列之间的调度(此文章未涉及)
// // 单线程和多线程并发队列测试(同步和异步) // // 基础原理: // 1)队列: // 1.1 dispatch_queue_t 是一个队列,一个FIFO的消费队列 // 1.2 消费者:队列配置的运行线程 // 1.3 被消费对象: 添加到队列中的运行任务(block等) // 1.4 运行任务:将任务放到队列中,等待消费者消费 // 2)同步,异步 (对于任务) (此处的运行指将任务发入到请求队列中) // 2.1 同步:A任务在运行时,插入B任务,A任务等待B任务运行完才能运行 // 2.2 异步: A任务在运行时,插入B任务,A任务不等待并且继续运行,B任务也运行 // 假设: // ATask: 运行fooA的Block // BTask: 运行fooB的Block // // // 总结: // 不管单线程或多线程,同步或异步,一定要联系请求队列考虑 #import "TestQueueSi.h" @interface TestQueueSi () @property (strong,nonatomic) dispatch_queue_t serialQueue; @property (strong,nonatomic) dispatch_queue_t concurrentQueue; @end @implementation TestQueueSi - (instancetype)init { self = [super init]; if(self) { _serialQueue = dispatch_queue_create("chenhh.serialQueue", DISPATCH_QUEUE_SERIAL); _concurrentQueue = dispatch_queue_create("chenhh.concurrentQueue", DISPATCH_QUEUE_CONCURRENT); } return self; } /** QUEUE_SERIAL(单线程) 同步 死锁崩溃 1.ATask运行,同步加入BTask 2.BTask加入到请求队列中,可是没有其他空余线程(ATask线程在 等待BTask),BTask等待空余线程, 3.死锁发生 */ - (void)testSerialQueueSync { dispatch_sync(_serialQueue,^{ [self fooA]; dispatch_sync(_serialQueue,^{ [self fooB]; }); [self fooA]; }); } /** QUEUE_CONCURRENT(多线程) 同步 正常运行 1.ATask运行,同步加入BTask,Atask线程等待 2.BTask加入到请求队列中,有其他空余线程(ATask线程在等待BTask),BTask运行 3.BTask运行结束,ATask停止等待,继续运行 */ - (void)testConcurrentQueueSync { dispatch_sync(_concurrentQueue,^{ [self fooA]; NSLog(@"first"); // 同步 需要等待运行结果 dispatch_sync(_concurrentQueue,^{ [self fooB]; }); // 等待同步代码完成,再运行 [self fooA]; }); } /* QUEUE_SERIAL(单线程) 异步 正常 1.ATask运行,异步加入BTask,Atask线程继续运行不等待 2.BTask加入到请求队列中,没有其他空余线程(ATask线程在正常运行),BTask等待空余 3.ATask运行完成,线程空出,BTask运行 */ - (void)testSerialQueueAsync { dispatch_async(_serialQueue,^{ [self fooA]; dispatch_async(_serialQueue,^{ [self fooB]; }); [self fooA]; }); } /** QUEUE_CONCURRENT(多线程) 异步 正常运行 1.ATask运行,同步加入BTask,Atask线程继续运行不等待 2.BTask加入到请求队列中,有其他空余线程(ATask等线程在正常运行),BTask运行(ABTask同时运行) */ - (void)testConcurrentQueueAsync { dispatch_async(_concurrentQueue,^{ [self fooA]; // 同步 需要等待运行结果 dispatch_async(_concurrentQueue,^{ [self fooB]; }); // 等待同步代码完成,再运行 [self fooA]; }); } - (void)fooA { NSLog(@" ************ fooA ************ "); } - (void)fooB { NSLog(@" ************ fooB ************ "); } @end