iOS笔记18

1
//根据环境进行相应的编译(arc和非arc)
#if __has_feature(objc_arc)
//当前环境是ARC
#else
//当前环境是MRC
-(oneway void)release
{
}
-(instancetype)retain
{
return _instance;
}

-(NSUInteger)retainCount
{
    return MAXFLOAT;
}
#endif

2
//宏定义拼接参数用 ..##..

define SingleH(name) +(instancetype)share##name;

3
//NSOperation和NSOperationQueue实现多线程的具体步骤
先将需要执行的操作封装到一个NSOperation对象中
然后将NSOperation对象添加到NSOperationQueue中
系统会自动将NSOperationQueue中的NSOperation取出来
将取出的NSOperation封装的操作放到一条新线程中执行

4
//NSOperation的子类
NSOperation是个抽象类,并不具备封装操作的能力,必须使用它的子类

使用NSOperation子类的方式有3种
    1> NSInvocationOperation
    2> NSBlockOperation
    3> 自定义子类继承NSOperation,实现内部相应的方法

5
//NSInvocationOperation
创建NSInvocationOperation对象
- (id)initWithTarget:(id)target selector:(SEL)sel object:(id)arg;

调用start方法开始执行操作
- (void)start;
一旦执行操作,就会调用target的sel方法

注意
默认情况下,调用了start方法后并不会开一条新线程去执行操作,而是在当前线程同步执行操作
只有将NSOperation放到一个NSOperationQueue中,才会异步执行操作

6
//NSBlockOperation
创建NSBlockOperation对象
+ (id)blockOperationWithBlock:(void (^)(void))block;

通过addExecutionBlock:方法添加更多的操作
- (void)addExecutionBlock:(void (^)(void))block;

注意:只要NSBlockOperation封装的操作数 > 1,就会异步执行操作

//例子
    -(void)blockOperation
    {
        //1.封装操作
        NSBlockOperation *op1 = [NSBlockOperation blockOperationWithBlock:^{
            //在主线程执行
            NSLog(@"1----%@",[NSThread currentThread]);
        }];


        //添加额外的任务,一定是在子线程执行
        [op1 addExecutionBlock:^{
            NSLog(@"3----%@",[NSThread currentThread]);
        }];

        [op1 addExecutionBlock:^{
            NSLog(@"4----%@",[NSThread currentThread]);
        }];
        //2.执行操作
        [op1 start];

}

7
//NSOperationQueue
NSOperationQueue的作用
NSOperation可以调用start方法来执行任务,但默认是同步执行的
如果将NSOperation添加到NSOperationQueue(操作队列)中,系统会自动异步执行NSOperation中的操作

添加操作到NSOperationQueue中
- (void)addOperation:(NSOperation *)op;
- (void)addOperationWithBlock:(void (^)(void))block;

8
//NSOperationQueue 和 NSInvocationOperation
- (void)invocationOperatonAndOperatonQueue
{
NSOperationQueue *queue = [[NSOperationQueue alloc] init];

    NSInvocationOperation *op1 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(download1) object:nil];

    NSInvocationOperation *op2 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(download2) object:nil];

    [queue addOperation:op1];
    [queue addOperation:op2];
    //两个都是在非主线程中执行
}

9
//NSOperationQueue 和 自定义 operation
NSOperationQueue *queue = [[NSOperationQueue alloc] init];
MyOperation *op1 = [[MyOperation alloc] init];
MyOperation *op2 = [[MyOperation alloc] init];

[queue addOperation:op1];
[queue addOperation:op2];
//都是在非主线程中执行

10
//NSOperationQueue 和 NSBlockOperation (addOperationWithBlock)
- (void)blockOperationAndOperationQueue
{
NSOperationQueue *queue = [[NSOperationQueue alloc] init];

    NSBlockOperation *op1 = [NSBlockOperation blockOperationWithBlock:^{
        NSLog(@"1--------%@",[NSThread currentThread]);
    }];

    NSBlockOperation *op2 = [NSBlockOperation blockOperationWithBlock:^{
        NSLog(@"2--------%@",[NSThread currentThread]);
    }];

    [op2 addExecutionBlock:^{
        NSLog(@"2.2-------%@",[NSThread currentThread]);
    }];

    [queue addOperation:op1];
    [queue addOperation:op2];

    //简便方法
    [queue addOperationWithBlock:^{
        NSLog(@"3-------%@",[NSThread currentThread]);
    }];

}

10
//最大并发数 setMaxConcurrentOperationCount
什么是并发数
同时执行的任务数
比如,同时开3个线程执行3个任务,并发数就是3

最大并发数的相关方法
- (NSInteger)maxConcurrentOperationCount;
- (void)setMaxConcurrentOperationCount:(NSInteger)cnt;

self.queue.maxConcurrentOperationCount = 5

11
//队列的取消、暂停、恢复(不能取消/暂停当前正在执行的操作 )
取消队列的所有操作
- (void)cancelAllOperations;
提示:也可以调用NSOperation的- (void)cancel方法取消单个操作

暂停和恢复队列
- (void)setSuspended:(BOOL)b; // YES代表暂停队列,NO代表恢复队列
- (BOOL)isSuspended;

//不能暂停当前正在执行的操作,只对下一个操作有效
//当为YES的时候,表示暂停
//当为NO的时候,表示恢复
    if (self.queue.isSuspended) {
         self.queue.suspended = NO;
    }else
    {
         self.queue.suspended = YES;
    }

//不能取消当前正在执行的操作,只对后面有效
[self.queue cancelAllOperations];

12
//操作依赖 addDependency
NSOperation之间可以设置依赖来保证执行顺序
比如一定要让操作A执行完后,才能执行操作B,可以这么写
[operationB addDependency:operationA]; // 操作B依赖于操作A

可以在不同queue的NSOperation之间创建依赖关系

注意:不能相互依赖
比如A依赖B,B依赖A
//添加依赖.注意不能循环依赖
[op1 addDependency:op2];
[op2 addDependency:op3];

[queue addOperation:op1];
[queue addOperation:op2];
[queue addOperation:op3];
//根据依赖可以控制执行的顺序 op3-->op2-->op1

13
//操作的监听
可以监听一个操作的执行完毕
- (void (^)(void))completionBlock;
- (void)setCompletionBlock:(void (^)(void))block;

14
//自定义NSOperation
自定义NSOperation的步骤很简单
重写- (void)main方法,在里面实现想执行的任务

重写- (void)main方法的注意点
自己创建自动释放池(因为如果是异步操作,无法访问主线程的自动释放池)
经常通过- (BOOL)isCancelled方法检测操作是否被取消,对取消做出响应

//具体代码
.h
#import

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值