iOS多线程GCD 研究
Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法。 
dispatch queue分成以下三种: 
1)运行在主线程的Main queue,通过dispatch_get_main_queue获取。
- /*!
 - * @function dispatch_get_main_queue
 - *
 - * @abstract
 - * Returns the default queue that is bound to the main thread.
 - *
 - * @discussion
 - * In order to invoke blocks submitted to the main queue, the application must
 - * call dispatch_main(), NSApplicationMain(), or use a CFRunLoop on the main
 - * thread.
 - *
 - * @result
 - * Returns the main queue. This queue is created automatically on behalf of
 - * the main thread before main() is called.
 - */
 - __OSX_AVAILABLE_STARTING(__MAC_10_6,__IPHONE_4_0)
 - DISPATCH_EXPORT struct dispatch_queue_s _dispatch_main_q;
 - #define dispatch_get_main_queue() \
 - DISPATCH_GLOBAL_OBJECT(dispatch_queue_t, _dispatch_main_q)
 
/*!
* @function dispatch_get_main_queue
*
* @abstract
* Returns the default queue that is bound to the main thread.
*
* @discussion
* In order to invoke blocks submitted to the main queue, the application must
* call dispatch_main(), NSApplicationMain(), or use a CFRunLoop on the main
* thread.
*
* @result
* Returns the main queue. This queue is created automatically on behalf of
* the main thread before main() is called.
*/
__OSX_AVAILABLE_STARTING(__MAC_10_6,__IPHONE_4_0)
DISPATCH_EXPORT struct dispatch_queue_s _dispatch_main_q;
#define dispatch_get_main_queue() \
DISPATCH_GLOBAL_OBJECT(dispatch_queue_t, _dispatch_main_q)
可以看出,dispatch_get_main_queue也是一种dispatch_queue_t。 
2)并行队列global dispatch queue,通过dispatch_get_global_queue获取,由系统创建三个不同优先级的dispatch queue。并行队列的执行顺序与其加入队列的顺序相同。 
3)串行队列serial queues一般用于按顺序同步访问,可创建任意数量的串行队列,各个串行队列之间是并发的。 
当想要任务按照某一个特定的顺序执行时,串行队列是很有用的。串行队列在同一个时间只执行一个任务。我们可以使用串行队列代替锁去保护共享的数据。和锁不同,一个串行队列可以保证任务在一个可预知的顺序下执行。 
serial queues通过dispatch_queue_create创建,可以使用函数dispatch_retain和dispatch_release去增加或者减少引用计数。 
GCD的用法:
- // 后台执行:
 - dispatch_async(dispatch_get_global_queue(0, 0), ^{
 - // something
 - });
 - // 主线程执行:
 - dispatch_async(dispatch_get_main_queue(), ^{
 - // something
 - });
 - // 一次性执行:
 - static dispatch_once_t onceToken;
 - dispatch_once(&onceToken, ^{
 - // code to be executed once
 - });
 - // 延迟2秒执行:
 - double delayInSeconds = 2.0;
 - dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC);
 - dispatch_after(popTime, dispatch_get_main_queue(), ^(void){
 - // code to be executed on the main queue after delay
 - });
 - // 自定义dispatch_queue_t
 - dispatch_queue_t urls_queue = dispatch_queue_create("blog.devtang.com", NULL);
 - dispatch_async(urls_queue, ^{
 - // your code
 - });
 - dispatch_release(urls_queue);
 - // 合并汇总结果
 - dispatch_group_t group = dispatch_group_create();
 - dispatch_group_async(group, dispatch_get_global_queue(0,0), ^{
 - // 并行执行的线程一
 - });
 - dispatch_group_async(group, dispatch_get_global_queue(0,0), ^{
 - // 并行执行的线程二
 - });
 - dispatch_group_notify(group, dispatch_get_global_queue(0,0), ^{
 - // 汇总结果
 - });
 
// 后台执行:
dispatch_async(dispatch_get_global_queue(0, 0), ^{
// something
}); // 主线程执行:
dispatch_async(dispatch_get_main_queue(), ^{
// something
}); // 一次性执行:
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
// code to be executed once
}); // 延迟2秒执行:
double delayInSeconds = 2.0;
dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC);
dispatch_after(popTime, dispatch_get_main_queue(), ^(void){
// code to be executed on the main queue after delay
}); // 自定义dispatch_queue_t
dispatch_queue_t urls_queue = dispatch_queue_create("blog.devtang.com", NULL);
dispatch_async(urls_queue, ^{
// your code
});
dispatch_release(urls_queue); // 合并汇总结果
dispatch_group_t group = dispatch_group_create();
dispatch_group_async(group, dispatch_get_global_queue(0,0), ^{
// 并行执行的线程一
});
dispatch_group_async(group, dispatch_get_global_queue(0,0), ^{
// 并行执行的线程二
});
dispatch_group_notify(group, dispatch_get_global_queue(0,0), ^{
// 汇总结果
});
一个应用GCD的例子:
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
 - NSURL * url = [NSURL URLWithString:@"http://www.baidu.com"];
 - NSError * error;
 - NSString * data = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:&error];
 - if (data != nil) {
 - dispatch_async(dispatch_get_main_queue(), ^{
 - NSLog(@"call back, the data is: %@", data);
 - });
 - } else {
 - NSLog(@"error when download:%@", error);
 - }
 - });
 
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
        NSURL * url = [NSURL URLWithString:@"http://www.baidu.com"];
        NSError * error;
        NSString * data = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:&error];
        if (data != nil) {
            dispatch_async(dispatch_get_main_queue(), ^{
                NSLog(@"call back, the data is: %@", data);
            });
        } else {
            NSLog(@"error when download:%@", error);
        }
    });
GCD的另一个用处是可以让程序在后台较长久的运行。 
在没有使用GCD时,当app被按home键退出后,app仅有最多5秒钟的时候做一些保存或清理资源的工作。但是在使用GCD后,app最多有10分钟的时间在后台长久运行。这个时间可以用来做清理本地缓存,发送统计数据等工作。 
让程序在后台长久运行的示例代码如下:
- // AppDelegate.h文件
 - @property (assign, nonatomic) UIBackgroundTaskIdentifier backgroundUpdateTask;
 - // AppDelegate.m文件
 - - (void)applicationDidEnterBackground:(UIApplication *)application
 - {
 - [self beingBackgroundUpdateTask];
 - // 在这里加上你需要长久运行的代码
 - [self endBackgroundUpdateTask];
 - }
 - - (void)beingBackgroundUpdateTask
 - {
 - self.backgroundUpdateTask = [[UIApplication sharedApplication] beginBackgroundTaskWithExpirationHandler:^{
 - [self endBackgroundUpdateTask];
 - }];
 - }
 - - (void)endBackgroundUpdateTask
 - {
 - [[UIApplication sharedApplication] endBackgroundTask: self.backgroundUpdateTask];
 - self.backgroundUpdateTask = UIBackgroundTaskInvalid;
 - }
 
iOS多线程GCD 研究的更多相关文章
- iOS多线程 GCD
		
iOS多线程 GCD Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法. dispatch queue分成以下三种: 1)运行在主线程的Main que ...
 - iOS 多线程GCD的基本使用
		
<iOS多线程简介>中提到:GCD中有2个核心概念:1.任务(执行什么操作)2.队列(用来存放任务) 那么多线程GCD的基本使用有哪些呢? 可以分以下多种情况: 1.异步函数 + 并发队列 ...
 - iOS 多线程 GCD part3:API
		
https://www.jianshu.com/p/072111f5889d 2017.03.05 22:54* 字数 1667 阅读 88评论 0喜欢 1 0. 预备知识 GCD对时间的描述有些新奇 ...
 - ios多线程-GCD基本用法
		
ios中多线程有三种,NSTread, NSOperation,GCD 这篇就讲讲GCD的基本用法 平时比较多使用和看到的是: dispatch_async(dispatch_get_global_q ...
 - iOS多线程——GCD与NSOperation总结
		
很长时间以来,我个人(可能还有很多同学),对多线程编程都存在一些误解.一个很明显的表现是,很多人有这样的看法: 新开一个线程,能提高速度,避免阻塞主线程 毕竟多线程嘛,几个线程一起跑任务,速度快,还不 ...
 - iOS多线程GCD的使用
		
1. GCD 简介 Grand Central Dispatch(GCD)是异步执行任务的技术之一.一般将应用程序中记述的线程管理用的代码在系统级中实现.开发者只需要定义想执行的任务并追加到适当的Di ...
 - iOS多线程GCD详解
		
在这之前,一直有个疑问就是:gcd的系统管理多线程的概念,如果你看到gcd管理多线程你肯定也有这样的疑问,就是:并发队列怎么回事,即是队列(先进先出)怎么会并发,本人郁闷了好久,才发现其实cgd管理多 ...
 - iOS多线程GCD的简单使用
		
在iOS开发中,苹果提供了三种多线程技术,分别是: (1)NSThread (2)NSOperation (3)GCD 简单介绍一下GCD的使用. GCD全称 Grand Central Dispat ...
 - iOS多线程——GCD篇
		
什么是GCD GCD是苹果对多线程编程做的一套新的抽象基于C语言层的API,结合Block简化了多线程的操作,使得我们对线程操作能够更加的安全高效. 在GCD出现之前Cocoa框架提供了NSObjec ...
 
随机推荐
- # 基于Gitolite搭建Git Server - 支持SSH&HTTP
			
Git, 一个分布式的版本管理工具,我认为其革命性的点:在于改变了用户协作的方式,使得协作更简单. 下面讲述 使用一个开源软件 Gitolite搭建一个Git Sever, 并给了一个推荐的团队协助方 ...
 - GSS5 spoj 2916. Can you answer these queries V 线段树
			
gss5 Can you answer these queries V 给出数列a1...an,询问时给出: Query(x1,y1,x2,y2) = Max { A[i]+A[i+1]+...+A[ ...
 - vijos 1053Easy sssp
			
P1053Easy sssp Accepted 标签:图结构 最短路 描述 输入数据给出一个有N(2 <= N <= 1,000)个节点,M(M <= 100,000)条边的 ...
 - Android聊天界面刷新消息
			
今天,我想来分享一下自己初用线程的感受,虽然写法略显粗糙,并没有用线程Thread中核心的Looper,MessageQueue消息队列这些知识,正因为是初学线程,所以就只用最基础的来写了,慢慢学习优 ...
 - Varnish缓存服务器的搭建配置手册
			
Varnish缓存服务器的搭建配置手册 1.Varnish官方环境依赖提示 Installing Varnish Cache is as simple as enabling our package ...
 - Sql Server 数据库之间如何进行跨网远程连接访问
			
场景说明 现在有一台A电脑和一台B电脑,两台电脑都安装了Sql Server数据库,两台电脑不在一个局域网(我们考虑的是不同网络的两台数据库连接),比如A电脑在公司,B电脑在家里,现在我要在家里用B电 ...
 - Cocos2d-JS中的精灵菜单和图片菜单
			
精灵菜单的菜单项类是cc.MenuItemSprite,图片菜单的菜单项类是cc.MenuItemImage.由于cc.MenuItemImage继承于cc.MenuItemSprite,所以图片菜单 ...
 - Linux基本服务命令
			
启动Httpd服务:service httpd start 停止Httpd服务:service httpd stop 重启Httpd服务:service httpd restart 关闭httpd所有 ...
 - CXF和Axis的比较【转】
			
在SOA领域,我们认为Web Service是SOA体系的构建单元(building block).对于服务开发人员来说,AXIS和CXF一定都不会陌生.这两个产品都是Apache孵化器下面的Web ...
 - 从malloc中窥探Linux内存分配策略
			
malloc函数是C/C++中常用内存分配库函数,本篇文章将以Linux平台上的malloc为剖析对象,深入了解分配一块内存的旅程. malloc入门 使用malloc,需要包含头文 ...