线程同步:就是多个线程同时访问同一资源,必须等一个线程访问结束,才能访问其它资源,比较浪费时间,效率低
线程异步:访问资源时在空闲等待时可以同时访问其他资源,实现多线程机制
说起来比较抽象,我用代码尝试了一下
//以异步的方式提交队列
-(void)async
{
dispatch_async(q1, ^{
for (int i = 0; i < 10; i ++) {
NSLog(@"q1=====%d",i);
}
});
}
//以同步的方式提交队列
-(void)sync
{
dispatch_sync(q1, ^{
for (int i = 0; i < 10; i ++) {
NSLog(@"q2-----%d",i);
}
});
}
先用以异步的方式提交队列
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
q1 = dispatch_queue_create("q1", DISPATCH_QUEUE_SERIAL);
[self async];
//[self sync];
NSLog(@"1111");
return YES;
}
输出如下
2016-08-15 22:21:06.341 TPZhihuDailyPurify[2076:1215297] q2—–8
2016-08-15 22:21:06.341 TPZhihuDailyPurify[2076:1215297] q2—–9
2016-08-15 22:21:06.341 TPZhihuDailyPurify[2076:1215297] 1111
2016-08-15 22:21:06.340 TPZhihuDailyPurify[2076:1215902] q1=====7
2016-08-15 22:21:06.342 TPZhihuDailyPurify[2076:1215902] q1=====8
2016-08-15 22:21:06.343 TPZhihuDailyPurify[2076:1215902] q1=====9
当然这个1111的位置每次运行都可能不一样因为系统是在空闲时访问其它资源,也就是程序继续往下运行,输出1111。
再用以同步的方式提交队列
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
q1 = dispatch_queue_create("q1", DISPATCH_QUEUE_SERIAL);
//[self async];
[self sync];
NSLog(@"1111");
return YES;
}
输出如下
016-08-15 22:26:09.541 TPZhihuDailyPurify[2099:1246463] q2—–5
2016-08-15 22:26:09.541 TPZhihuDailyPurify[2099:1246463] q2—–6
2016-08-15 22:26:09.541 TPZhihuDailyPurify[2099:1246463] q2—–7
2016-08-15 22:26:09.542 TPZhihuDailyPurify[2099:1246463] q2—–8
2016-08-15 22:26:09.542 TPZhihuDailyPurify[2099:1246463] q2—–9
2016-08-15 22:26:09.542 TPZhihuDailyPurify[2099:1246463] 1111
可以看出1111总是在最后输出,因为同步必须等一个线程访问结束,才能访问其他资源,也就是程序继续往下运行。