1.串行队列:Dispatch Queues或者 Serial Queues
并发
同步
- dispatch_queue_t queue = dispatch_queue_create("zenny_chen_firstQueue", nil);
-
- dispatch_sync(queue, ^(void) {
-
-
- sleep(2-i/50);
- NSLog(@"The sum is: %d", i);
-
-
- });
- dispatch_release(queue);
异步
- dispatch_queue_t queue = dispatch_queue_create("zenny_chen_firstQueue", nil);
- dispatch_async(queue, ^(void) {
- sleep(2-i/50);
- NSLog(@"The sum is: %d", i);
-
-
-
- });
- dispatch_release(queue);
当主线程在等待信号量时,操做系统会直接将它挂起,所以不会去死作标志轮询,而可以及时将CPU资源给其它可被调度的线程使用。app
- __block dispatch_semaphore_t sem = dispatch_semaphore_create(0);
-
- dispatch_queue_t queue = dispatch_queue_create("zenny_chen_firstQueue", nil);
- dispatch_async(queue, ^(void) {
- sleep(2-i/50);
- NSLog(@"The sum is: %d", i);
-
-
- dispatch_semaphore_signal(sem);
- });
-
-
- dispatch_semaphore_wait(sem, DISPATCH_TIME_FOREVER);
-
- dispatch_release(queue);
2.并发队列 :Concurrent Queues
异步
- dispatch_queue_t aQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
- dispatch_queue_t aHQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0);
- dispatch_queue_t aLQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_LOW, 0);
3.主队列:main dispatch Queueasync
- dispatch_queue_t mainQueue = dispatch_get_main_queue();
针对以上3种队列:concurrent queues和main queue都是由系统生成并且 dispatch_suspend, dispatch_resume, dispatch_set_context这些函数对他们无效。函数
可是咱们的应用不是简单的同步也异步的运行,应用常常是混合的。oop
好比咱们要task1 task2 task3都运行完成后才能异步运行task4 task5 task6咱们该怎么作呢?这里咱们能够引入group的概念。this
- -(void)sixthMethod{
-
- dispatch_queue_t aQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
-
- dispatch_group_t queueGroup = dispatch_group_create();
-
- dispatch_group_async(queueGroup, aQueue, ^{
- NSLog(@"task 1.");
- });
-
- dispatch_group_async(queueGroup, aQueue, ^{
- NSLog(@"task 2.");
- });
-
- dispatch_group_async(queueGroup, aQueue, ^{
- NSLog(@"task 3.");
- });
- NSLog(@"wait task 1,2,3.");
-
- dispatch_group_wait(queueGroup, DISPATCH_TIME_FOREVER);
- NSLog(@"task 1,2,3 finished.");
-
- dispatch_release(queueGroup);
-
- queueGroup = dispatch_group_create();
-
- dispatch_group_async(queueGroup, aQueue, ^{
- NSLog(@"task 4.");
- });
-
- dispatch_group_async(queueGroup, aQueue, ^{
- NSLog(@"task 5.");
- });
-
- dispatch_group_async(queueGroup, aQueue, ^{
- NSLog(@"task 6.");
- });
- NSLog(@"wait task 4,5,6.");
-
- dispatch_group_wait(queueGroup, DISPATCH_TIME_FOREVER);
- NSLog(@"task 4,5,6 finished.");
-
- dispatch_release(queueGroup);
- }
代码运行结果:
2013-05-13 13:55:33.783 GDC[2466:1303] task 1. 2013-05-13 13:55:33.783 GDC[2466:3a07] task 3. 2013-05-13 13:55:33.783 GDC[2466:c07] wait task 1,2,3. 2013-05-13 13:55:33.783 GDC[2466:1903] task 2. 2013-05-13 13:55:33.787 GDC[2466:c07] task 1,2,3 finished. 2013-05-13 13:55:33.788 GDC[2466:c07] wait task 4,5,6. 2013-05-13 13:55:33.788 GDC[2466:1303] task 4. 2013-05-13 13:55:33.788 GDC[2466:1903] task 5. 2013-05-13 13:55:33.788 GDC[2466:3a07] task 6. 2013-05-13 13:55:33.790 GDC[2466:c07] task 4,5,6 finished.