iOS开发经验总结itiOS多线程

IOS多线程-GCD

2015-07-09  本文已影响1362人  静之先生

GCD

什么是GCD

GCD的优势

GCD的核心概念

队列的类型

//通过直接创建的方式创建,参数决定是否是并发队列
//DISPATCH_QUEUE_CONCURRENT代表并发队列
//DISPATCH_QUEUE_SERIAL或NULL代表串行队列
//标示符代表这个队列的一个标记
dispatch_queue_t queue = dispatch_queue_create("标示符", DISPATCH_QUEUE_CONCURRENT);

//通过获取全局队列来获得一个并发队列
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
//这两个参数,第一个是优先级一般用默认,第二个直接设为0 是一个保留标记,实际作用不大
//直接创建
//DISPATCH_QUEUE_SERIAL或NULL代表串行队列
dispatch_queue_t queue = dispatch_queue_create("标示符", DISPATCH_QUEUE_SERIAL);
//获得主队列,也是一种串行队列
dispatch_queue_t queue = dispatch_get_main_queue();
//queue代表你要放入的队列
dispatch_sync(queue, ^{
        //在这里写要执行的代码
    });
//queue代表你要放入的队列
dispatch_async(queue, ^{
        //在这里写要执行的代码
    });
//隔断函数,前面执行完才会执行这个函数,这个函数执行完才会执行其他后面的函数
dispatch_barrier_async(dispatch_queue_t queue, dispatch_block_t block);
//全局并发情况下有问题

不同的队列与函数的组合会有不同的效果

线程之间通信示例

dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
        //在这里写上放在全局队列的代码
        dispatch_async(dispatch_get_main_queue(), ^{
            //写在这里就是执行主函数的代码
        });
    });

IOS上常见的延时代码

//调用NSObject的方法
[self performSelector:@selector(run) withObject:nil afterDelay:2.0];
// 2秒后再调用self的run方法

//使用GCD函数
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
    // 2秒后执行这里的代码...
});

//使用NSTimer
[NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(test) userInfo:nil repeats:NO];

Once代码,在整个程序运行时只执行一次

static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
    // 只执行1次的代码(这里面默认是线程安全的)
});

快速迭代代码

dispatch_apply(10, dispatch_get_global_queue(0, 0), ^(size_t index){
    // 执行10次代码,index顺序不确定
});

分组队列

//创建一个组组队队列
dispatch_group_t group =  dispatch_group_create();
//使用组队列异步函数,分别有组队列,和队列的参数.
dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
    // 执行1个耗时的异步操作
});
dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
    // 执行1个耗时的异步操作
});
dispatch_group_notify(group, dispatch_get_main_queue(), ^{
    // 等前面的异步操作都执行完毕后,回到主线程...
});

IOS中的单例模式

#import "Person.h"
@interface Person() <NSCopying>

@end

@implementation Person
//声明一个全局变量指针,代表唯一的实例
static Person *_person;
//重写alloc中实际起作用的部分,allocWihtZone,所以从始至终就只有一份存储空间.
+ (instancetype)allocWithZone:(struct _NSZone *)zone
{
    //在程序整个生命过程中只运行一次的代码
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{

        _person = [super allocWithZone:zone];
    });
    return _person;
}

//生成一个完整的对象
+ (instancetype)shareWihtPerson
{
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        _person = [[Person alloc] init];
    });
    return _person;
}

//防止使用copy拷贝出新的对象
- (id)copyWithZone:(NSZone *)zone
{
    return _person;
}

@end

上一篇 下一篇

猜你喜欢

热点阅读