NSOperationqueue的一些感悟
2016-05-10 17:06
387 查看
#import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor=[UIColor redColor]; NSOperationQueue *queue=[[NSOperationQueue alloc]init]; NSOperationQueue *queue2=[[NSOperationQueue alloc]init]; NSBlockOperation *operation1=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第一次:%@",[NSThread currentThread]); }]; NSBlockOperation *operation2=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第二次:%@",[NSThread currentThread]); }]; [operation1 addDependency:operation2]; [queue addOperation:operation1]; [queue addOperation:operation2 ]; NSBlockOperation *operation3=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第三次:%@",[NSThread currentThread]); }]; NSBlockOperation *operation4=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第四次:%@",[NSThread currentThread]); }]; [queue2 addOperation:operation4]; [queue2 addOperation:operation3];
2016-05-10 17:00:00.552 testobjectc[2305:152414] 执行第四次:<NSThread: 0x78e89910>{number = 2, name = (null)} 2016-05-10 17:00:00.552 testobjectc[2305:152410] 执行第二次:<NSThread: 0x78e60090>{number = 3, name = (null)} 2016-05-10 17:00:00.553 testobjectc[2305:152415] 执行第三次:<NSThread: 0x78fa4280>{number = 4, name = (null)} 2016-05-10 17:00:00.559 testobjectc[2305:152414] 执行第一次:<NSThread: 0x78e89910>{number = 2, name = (null)}
#import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor=[UIColor redColor]; NSOperationQueue *queue=[[NSOperationQueue alloc]init]; NSOperationQueue *queue2=[[NSOperationQueue alloc]init]; NSBlockOperation *operation1=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第一次:%@",[NSThread currentThread]); }]; NSBlockOperation *operation2=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第二次:%@",[NSThread currentThread]); }]; [operation1 addDependency:operation2]; [queue addOperation:operation1]; [queue addOperation:operation2 ]; NSBlockOperation *operation3=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第三次:%@",[NSThread currentThread]); }]; NSBlockOperation *operation4=[NSBlockOperation blockOperationWithBlock:^(){ NSLog(@"执行第四次:%@",[NSThread currentThread]); }]; [queue2 addOperation:operation4]; [queue2 addOperation:operation3];[self downLoad];
// Do any additional setup after loading the view, typically from a nib.
}
-(void)downLoad{
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
NSURL *url=[NSURL URLWithString:@"www.baidu.com"];
NSLog(@"%@",url);
dispatch_async(dispatch_get_main_queue(), ^{
self.view.backgroundColor=[UIColor blueColor];
});
});
}
2016-05-10 19:52:57.269 testobjectc[2631:181847] www.baidu.com 2016-05-10 19:52:57.269 testobjectc[2631:181844] 执行第四次:<NSThread: 0x7d0ad9b0>{number = 3, name = (null)} 2016-05-10 19:52:57.274 testobjectc[2631:181861] 执行第三次:<NSThread: 0x7be3dde0>{number = 4, name = (null)} 2016-05-10 19:52:57.269 testobjectc[2631:181848] 执行第二次:<NSThread: 0x7d00b570>{number = 2, name = (null)} 2016-05-10 19:52:57.277 testobjectc[2631:181848] 执行第一次:<NSThread: 0x7d00b570>{number = 2, name = (null)}
相关文章推荐
- String、StringBuffer与StringBuilder之间区别
- 【BZOJ-1568】Blue Mary开公司 李超线段树 (标记永久化)
- IQueryable & IEnumberable 区别
- String、StringBuffer与StringBuilder之间区别
- 安卓UI控件拖拽的几种方法
- UITableView的两种重用Cell方法的区别
- 关于UIKIT_EXTERN
- No 'Access-Control-Allow-Origin' header is present on the requested resource.
- NGUI-Sprite扩展镜像功能
- 内外分离接口依赖及UIScrollView知识点
- NGUI中不规则形状点击事件
- An error occurred while installing sqlite3 (1.3.11), and Bundler cannot continue
- UINavigationBar透明设置
- An error occurred while installing pcaprub (0.12.0), and Bundler cannot continue
- 获取GUID的方法
- django views中提示cannot convert dictionary update sequence element #0 to a sequence错误
- 自定义collectionViewFlowLayout让UICollectionView的item始终优先居左
- ThreadPoolExecutor使用和思考(上)-线程池大小设置与BlockingQueue的三种实现区别
- ecshop整合ueditor替换百度编辑器 ,解决ie浏览器下宽度为0的问题
- Hive分析窗口函数(四) LAG,LEAD,FIRST_VALUE,LAST_VALUE