配合使用NSOperation和NSOperationQueue也能实现多线程编程 编程
先将须要执行的操做封装到一个NSOperation对象中多线程
而后将NSOperation对象添加到NSOperationQueue中并发
系统会自动将NSOperationQueue中的NSOperation取出来异步
将取出的NSOperation封装的操做放到一条新线程中执行spa
NSOperation是个抽象类,并不具有封装操做的能力,必须使用它的子类线程
使用NSOperation子类的方式有3种:code
NSInvocationOperationorm
NSBlockOperation对象
自定义子类继承NSOperation,实现内部相应的方法继承
建立NSInvocationOperation对象
- (id)initWithTarget:(id)target selector:(SEL)sel object:(id)arg;
调用start方法开始执行操做
- (void)start; 一旦执行操做,就会调用target的sel方法
注意
默认状况下,调用了start方法后并不会开一条新线程去执行操做,而是在当前线程同步执行操做
只有将NSOperation放到一个NSOperationQueue中,才会异步执行操做
建立NSBlockOperation对象
+ (id)blockOperationWithBlock:(void (^)(void))block;
经过addExecutionBlock:方法添加更多的操做
- (void)addExecutionBlock:(void (^)(void))block; 注意:只要NSBlockOperation封装的操做数 > 1,就会异步执行操做
NSOperation能够调用start方法来执行任务,但默认是同步执行的
若是将NSOperation添加到NSOperationQueue(操做队列)中,系统会自动异步执行NSOperation中的操做
- (void)addOperation:(NSOperation *)op; - (void)addOperationWithBlock:(void (^)(void))block;
什么是并发数
同时执行的任务数
好比,同时开3个线程执行3个任务,并发数就是3
最大并发数的相关方法
- (NSInteger)maxConcurrentOperationCount; - (void)setMaxConcurrentOperationCount:(NSInteger)cnt;
取消队列的全部操做
- (void)cancelAllOperations; 提示:也能够调用NSOperation的- (void)cancel方法取消单个操做
暂停和恢复队列
- (void)setSuspended:(BOOL)b; // YES表明暂停队列,NO表明恢复队列 - (BOOL)isSuspended;
设置NSOperation在queue中的优先级,能够改变操做的执行优先级
- (NSOperationQueuePriority)queuePriority; - (void)setQueuePriority:(NSOperationQueuePriority)p;
优先级的取值
NSOperationQueuePriorityVeryLow = -8L, NSOperationQueuePriorityLow = -4L, NSOperationQueuePriorityNormal = 0, NSOperationQueuePriorityHigh = 4, NSOperationQueuePriorityVeryHigh = 8
NSOperation之间能够设置依赖来保证执行顺序
好比必定要让操做A执行完后,才能执行操做B,能够这么写
[operationB addDependency:operationA]; // 操做B依赖于操做A 能够在不一样queue的NSOperation之间建立依赖关系
能够监听一个操做的执行完毕 - (void (^)(void))completionBlock; - (void)setCompletionBlock:(void (^)(void))block;
自定义NSOperation的步骤很简单
重写- (void)main方法,在里面实现想执行的任务
重写- (void)main方法的注意点
本身建立自动释放池(由于若是是异步操做,没法访问主线程的自动释放池)
常常经过- (BOOL)isCancelled方法检测操做是否被取消,对取消作出响应