ios中的任务分段
工作比较忙,蛮久没有写东西了,今天我要写的是ios中的任务分段。大多数的情况下,我们用不到任务分段,但是如果我们是在执行比较频繁的函数或者这个函数是比较耗时, 某一条件下,我要执行新的任务,并且取消上次函数的执行。大家知道代码是顺序执行的,一旦开始了就无法终止,除非我们代码执行的时候做逻辑判断,在满足某一条件的时候提前 return掉这个函数,这样我们就实现了所谓的任务分段,在实际开发中是非常有用的。
NSOperation,为对任务分段提供了很好的支持,operation 提供一个 iscancled的标志位,表明这个opertaion对象是是不是被标识为cancel,并不是说这个operation已经cancel掉了,所以一旦我们要终止某个operation的时候,我们就告诉他我已经取消你了,你不要再往下执行了,赶紧返回吧。这个就在main 函数里面去做,是不是很简单呢?
首先我们声明一个Operation__,定义其三个分段任务,task_1,task_2,task_3.
#import <Foundation/Foundation.h> @interface Opration__ : NSOperation @property(nonatomic,copy)void (^task_1)(void);
@property(nonatomic,copy)void (^task_2)(void);
@property(nonatomic,copy)void (^task_3)(void); @end
这个三个task 就是我们要执行的三个任务,只要我们对象的当前状态是isCancled ,我们就不往下执行了。
#import "Opration__.h" static void *oprationFinishContext = &oprationFinishContext;
@implementation Opration__ - (void)prepareDealloc
{
self.task_1 = nil; self.task_2 = nil; self.task_3 = nil;
} - (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{ if ([keyPath isEqualToString:@"isFinished"])
{
[self prepareDealloc];
}
} - (id)init
{
self = [super init];
if (self) {
[self addObserver:self forKeyPath:@"isFinished" options:NSKeyValueObservingOptionInitial context:oprationFinishContext];
}
return self;
} - (void)main
{ if (self.isCancelled) {
return;
}
if (self.task_1) {
self.task_1();
}
if (self.isCancelled) {
return;
}
if (self.task_2) {
self.task_2();
} if (self.isCancelled) {
return;
}
if (self.task_3) {
self.task_3();
} }
@end
在假设大家都知道block指针和KVO的情况下,我接着往下讲,很显然我们只要在调用的时候cancel掉这个operation,main函数在执行的时候就能进行分段的执行,废话不多说,贴上代码一目了然。
#import "obj_a.h"
#import "Opration__.h"
@implementation obj_a
{
NSOperationQueue *_queue;
} - (void)dealloc
{
[_queue release];
[super dealloc]; } - (id)init
{
self = [super init];
if (self) {
_queue = [[NSOperationQueue alloc]init];
}
return self;
}
- (void)function1
{ Opration__ *op = [[[Opration__ alloc]init]autorelease];
op.task_1 = ^(void)
{
};
op.task_2 = ^(void)
{
};
op.task_3 = ^(void)
{
};
[_queue addOperation:op];
} - (void)function2
{
[_queue cancelAllOperations];
Opration__ *op_1 = [[[Opration__ alloc]init]autorelease];
op_1.task_1 = ^(void)
{
};
op_1.task_2 = ^(void)
{
};
op_1.task_3 = ^(void)
{
}; } @end
当上面的function1,fuction2顺序执行的时候,只要op还没执行结束,op的iscanceled就会为YES,这个时候我们main函数 就能分段执行了,当然你可以增加任务的个数,把任务分的更小。
有兴趣的同学可以下载到其中的operation文件。
ios中的任务分段的更多相关文章
- 从deque到std::stack,std::queue,再到iOS 中NSArray(CFArray)
从deque到std::stack,std::queue,再到iOS 中NSArray(CFArray) deque deque双端队列,分段连续空间数据结构,由中控的map(与其说map,不如说是数 ...
- iOS中支付宝集成
iOS中支付宝集成 如今各种的App中都使用了三方支付的功能,现在将我在使用支付宝支付集成过程的心得分享一下,希望对大家都能有所帮助 要集成一个支付宝支付过程的环境,大致需要: 1>公司:先与支 ...
- iOS中数据库应用基础
iOS 数据库入门 一.数据库简介 1.什么是数据库? 数据库(Database) 是按照数据结构来组织,存储和管理数据的仓库 数据库可以分为2大种类 关系型数据库(主流) PC端 Oracle My ...
- 正则表达式在iOS中的运用
1.什么是正则表达式 正则表达式,又称正规表示法,是对字符串操作的一种逻辑公式.正则表达式可以检测给定的字符串是否符合我们定义的逻辑,也可以从字符串中获取我们想要的特定部分.它可以迅速地用极简单的方式 ...
- iOS 中的 HotFix 方案总结详解
相信HotFix大家应该都很熟悉了,今天主要对于最近调研的一些方案做一些总结.iOS中的HotFix方案大致可以分为四种: WaxPatch(Alibaba) Dynamic Framework(Ap ...
- iOS中使用正则
一.什么是正则表达式 正则表达式,又称正规表示法,是对字符串操作的一种逻辑公式.正则表达式可以检测给定的字符串是否符合我们定义的逻辑,也可以从字符串中获取我们想要的特定部分.它可以迅速地用极简单的方式 ...
- IOS中div contenteditable=true无法输入
在IOS中<div contenteditable="true"></div>中点击时可以弹出键盘但是无法输入.加一个样式-webkit-user-sele ...
- 谈谈iOS中的屏幕方向
众所周知,iOS中提供了[UIDevice currentDevice].orientation与[UIApplication sharedApplication].statusBarOrientat ...
- iOS中assign、copy 、retain等关键字的含义
iOS中assign.copy .retain等关键字的含义 转自:http://my.oschina.net/majiage/blog/267409 assign: 简单赋值,不更改索引计数cop ...
随机推荐
- QT不让windows休眠的方法
对于一些Windows应用程序,必须要保证os不能休眠才能有效工作,如迅雷下载软件,如果os进入休眠,则会导致网络不正常,从而导致不能下载东西.那木有没有1种机制,当打开软件的时候,就自动将os设为不 ...
- Json.Net系列教程 4.Linq To JSON
原文 Json.Net系列教程 4.Linq To JSON 更改历史 2013-05-31 添加一个FAQ 一.Linq to JSON是用来干什么的? Linq to JSON是用来操作JSO ...
- php:根据中文裁减字符串函数方法
define(CHARSET, 'UTF-8'); // 系统默认编码 /** * 根据中文裁减字符串 * @param $string - 字符串 * @param $length - 长度 * @ ...
- 令人作呕的OpenSSL
在OpenSSL心脏出血之后,我相信非常多人都出了血,而且流了泪...网上瞬间出现了大量吐嘈OpenSSL的文章或段子,仿佛内心的窝火一瞬间被释放了出来,跟着这场疯闹,我也吐一下嘈,以雪这些年被Ope ...
- 查看Oracle数据库某用户的连接信息
执行以下语句可查出用户TJAMIS_LXF连接信息: select schemaname, osuser, process, machine, port, terminal, program from ...
- FreeCodeCamp:Slasher Flick
要求: 打不死的小强! 返回一个数组被截断n个元素后还剩余的元素,截断从索引0开始. 结果: slasher([1, 2, 3], 2) 应该返回 [3]. slasher([1, 2, 3], 0) ...
- BZOJ 3304: [Shoi2005]带限制的最长公共子序列( LCS )
求个LCS, 只是有了限制, 多加一维表示匹配到z串的第几个, 然后用滚动数组 ------------------------------------------------------------ ...
- BZOJ 1646: [Usaco2007 Open]Catch That Cow 抓住那只牛( BFS )
BFS... -------------------------------------------------------------------------------------------- ...
- Python学习之day4
参考文献:http://www.cnblogs.com/alex3714/articles/5143440.html 迭代器: 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直 ...
- C语言之辗转相除法
最大公约数和最小公倍数 从键盘输入两个正整数,求出其最大公约数和最小公倍数.代码如下: #include<stdio.h>int ss(int);int main(void){ int a ...