同步:不会开辟新线程 dispatch_sync
异步:开辟新线程 dispatch_async
串行:必须等待前一个任务完成才会继续执行下一个任务
dispatch_queue_t queue=dispatch_queue_create("test",NULL);
并行:可以多个任务同时执行
dispatch_queue_t queue=dispatch_get_global_queue(0, 0);
一、同步串行
1、创建一个串行队列 是C语言不能写成nil
dispatch_queue_t queue=dispatch_queue_create("test",NULL);
同步任务
dispatch_sync(queue, ^{
// 执行的任务体
NSLog(@"当前线程%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"i===%d",i);
}
});
dispatch_sync(queue, ^{
// 执行的任务体
NSLog(@"当前线程1%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"j===%d",i);
}
});
输出:
2016-04-29 15:10:53.430 多线程--GCD[3594:204068] 主线程<NSThread: 0x7f9b1af04fc0>{number = 1, name = main}
2016-04-29 15:10:53.431 多线程--GCD[3594:204068] 当前线程<NSThread: 0x7f9b1af04fc0>{number = 1, name = main}
// 异步串行(创建新线程 执行按顺序)
NSLog(@"主线程%@",[NSThread currentThread]);
//创建一个串行的队列 这是C
dispatch_queue_t queue=dispatch_queue_create("test",NULL);
//异步任务
dispatch_async(queue, ^{
NSLog(@"当前线程%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"i===%d",i);
}
});
dispatch_async(queue, ^{
// 执行的任务体
NSLog(@"当前线程1%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"j===%d",i);
}
});
2016-04-29 15:12:01.869 多线程--GCD[3612:205160] 主线程<NSThread: 0x7f83b3c01410>{number = 1, name = main}
2016-04-29 15:12:01.870 多线程--GCD[3612:205195] 当前线程<NSThread: 0x7f83b3d0ab50>{number = 2, name = (null)}
创建新线程 执行按顺序
三、同步并行
// 同步并行
NSLog(@"主线程%@",[NSThread currentThread]);
//创建一个并行的队列 这是C
dispatch_queue_t queue=dispatch_get_global_queue(0, 0);
dispatch_sync(queue, ^{
// 执行的任务体
NSLog(@"当前线程%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"i===%d",i);
}
});
dispatch_sync(queue, ^{
// 执行的任务体
NSLog(@"当前线程1%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"j===%d",i);
}
});
2016-04-29 15:22:38.408 多线程--GCD[3653:211984] 主线程<NSThread: 0x7fbef94025b0>{number = 1, name = main}
2016-04-29 15:22:38.409 多线程--GCD[3653:211984] 当前线程<NSThread: 0x7fbef94025b0>{number = 1, name = main}
i 全部输出之后 在输出j
(不会开辟新线程 并且 并行失效)
四、异步并行
NSLog(@"主线程%@",[NSThread currentThread]);
// 创建并行
dispatch_queue_t queue=dispatch_get_global_queue(0, 0);
dispatch_async(queue, ^{
NSLog(@"当前线程%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"i===%d",i);
}
});
dispatch_async(queue, ^{
// 执行的任务体
NSLog(@"当前线程1%@",[NSThread currentThread]);
for(int i=0;i<50;i++)
{
NSLog(@"j===%d",i);
}
});
2016-04-29 15:24:16.619 多线程--GCD[3672:213395] 当前线程<NSThread: 0x7f8bb2e0e9f0>{number = 2, name = (null)}
2016-04-29 15:24:16.619 多线程--GCD[3672:213393] 当前线程1<NSThread: 0x7f8bb2c42460>{number = 3, name = (null)}