iOS App进入后台获取更多的运行时间
2013-11-12 18:19
302 查看
转载自:http://blog.csdn.net/happyhell/article/details/8974765
切克闹 代码实现:
@interface AppDelegate :
UIResponder <UIApplicationDelegate,WXApiDelegate,UIAlertViewDelegate>
{
__block
UIBackgroundTaskIdentifier _bgTask;
}
。。。
.m中实现:
- (void)backgroundHandler
{
UIApplication* app = [UIApplication
sharedApplication];
if (_bgTask !=
UIBackgroundTaskInvalid){
[app endBackgroundTask:_bgTask];
_bgTask =
UIBackgroundTaskInvalid;
}
_bgTask = [app
beginBackgroundTaskWithExpirationHandler:^{
[app endBackgroundTask:_bgTask];
_bgTask =
UIBackgroundTaskInvalid;
}];
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,
0), ^{
while (1){
sleep(1);
if (app.applicationState !=
UIApplicationStateBackground){
break;
}
}
});
}
- (void)applicationDidEnterBackground:(UIApplication *)application
{
[self
backgroundHandler];
}
- (void)applicationDidBecomeActive:(UIApplication *)application
{
//notification
application.applicationIconBadgeNumber =
0;
[application cancelAllLocalNotifications];
if (_bgTask !=
UIBackgroundTaskInvalid){
[application endBackgroundTask:_bgTask];
_bgTask =
UIBackgroundTaskInvalid;
}
if (![[GNXMPPEngine
sharedInstance] havConnect]){
[[GNXMPPEngine
sharedInstance] connect];
}
}
当App进入后台时(按下Home键), App会被系统暂停, 所有的程序逻辑都会停止, App还是驻留内存中, 除非被用户强制退出, 或者被系统kill掉(为了保证正在前台运行的App有足够的内存, 系统会选择性的kill掉后台的其他App), 当然这个和本文讨论的主题不太相关, 本文要讲的是如何让进入后台的App争取更多的运行时间而不是被马上暂停掉. 当程序进入后台, 我们有时需要做一些网络通信, 比如向服务器发送一些状态数据, 可能这些操作不会太耗时, 但是会被系统暂停掉, 我们需要争取一些时间完成这些操作,
下面讲如何争取更多的运行时间.
假设我们需要后台执行的逻辑写在RootController中, 那么在RootController中, 先声明一个实例变量, 和一个方法, 类似
@interface RootViewController : UIViewController
{
UIBackgroundTaskIdentifier backgroundTask; //用来保存后台运行任务的标示符
}
- (void)startBackgroundTask;
实现:
- (void)startBackgroundTask
{
UIApplication *application = [UIApplication sharedApplication];
//通知系统, 我们需要后台继续执行一些逻辑
backgroundTask = [application beginBackgroundTaskWithExpirationHandler:^{
//超过系统规定的后台运行时间, 则暂停后台逻辑
[application endBackgroundTask:backgroundTask];
backgroundTask = UIBackgroundTaskInvalid;
}];
//判断如果申请失败了, 返回
if (backgroundTask == UIBackgroundTaskInvalid) {
NSLog(@"beginground error");
return;
}
//已经成功向系统争取了一些后台运行时间, 实现一些逻辑, 如网络处理
//some code
}
当我们的任务已经完成, 如网络请求完成, 最好通知系统后台的逻辑已经完成了
//如, 网络处理结束
- (void)requestFinished
{
if (backgroundTask != UIBackgroundTaskInvalid) {
[[UIApplication sharedApplication] endBackgroundTask:backgroundTask];
backgroundTask = UIBackgroundTaskInvalid;
}
}
系统进入后台会自动调用Appdelegate中的- (void)applicationDidEnterBackground:(UIApplication *)application 这个方法, 我们要在这里手动调用RootController的startBackgroundTask方法
- (void)applicationDidEnterBackground:(UIApplication *)application
{
[rootController startBackgroundTask];
}
这样, 我们就可以在后台继续运行我们需要处理的逻辑了, 这里需要注意两点:
1、App进入后台最多只能运行10分钟,
2、如果超过了系统允许的时间没有调用endBackgroundTask:这个方法继续执行逻辑, App会被系统kill掉.
参考资料:
UIApplication
Class Reference
切克闹 代码实现:
@interface AppDelegate :
UIResponder <UIApplicationDelegate,WXApiDelegate,UIAlertViewDelegate>
{
__block
UIBackgroundTaskIdentifier _bgTask;
}
。。。
.m中实现:
- (void)backgroundHandler
{
UIApplication* app = [UIApplication
sharedApplication];
if (_bgTask !=
UIBackgroundTaskInvalid){
[app endBackgroundTask:_bgTask];
_bgTask =
UIBackgroundTaskInvalid;
}
_bgTask = [app
beginBackgroundTaskWithExpirationHandler:^{
[app endBackgroundTask:_bgTask];
_bgTask =
UIBackgroundTaskInvalid;
}];
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,
0), ^{
while (1){
sleep(1);
if (app.applicationState !=
UIApplicationStateBackground){
break;
}
}
});
}
- (void)applicationDidEnterBackground:(UIApplication *)application
{
[self
backgroundHandler];
}
- (void)applicationDidBecomeActive:(UIApplication *)application
{
//notification
application.applicationIconBadgeNumber =
0;
[application cancelAllLocalNotifications];
if (_bgTask !=
UIBackgroundTaskInvalid){
[application endBackgroundTask:_bgTask];
_bgTask =
UIBackgroundTaskInvalid;
}
if (![[GNXMPPEngine
sharedInstance] havConnect]){
[[GNXMPPEngine
sharedInstance] connect];
}
}
当App进入后台时(按下Home键), App会被系统暂停, 所有的程序逻辑都会停止, App还是驻留内存中, 除非被用户强制退出, 或者被系统kill掉(为了保证正在前台运行的App有足够的内存, 系统会选择性的kill掉后台的其他App), 当然这个和本文讨论的主题不太相关, 本文要讲的是如何让进入后台的App争取更多的运行时间而不是被马上暂停掉. 当程序进入后台, 我们有时需要做一些网络通信, 比如向服务器发送一些状态数据, 可能这些操作不会太耗时, 但是会被系统暂停掉, 我们需要争取一些时间完成这些操作,
下面讲如何争取更多的运行时间.
假设我们需要后台执行的逻辑写在RootController中, 那么在RootController中, 先声明一个实例变量, 和一个方法, 类似
@interface RootViewController : UIViewController
{
UIBackgroundTaskIdentifier backgroundTask; //用来保存后台运行任务的标示符
}
- (void)startBackgroundTask;
实现:
- (void)startBackgroundTask
{
UIApplication *application = [UIApplication sharedApplication];
//通知系统, 我们需要后台继续执行一些逻辑
backgroundTask = [application beginBackgroundTaskWithExpirationHandler:^{
//超过系统规定的后台运行时间, 则暂停后台逻辑
[application endBackgroundTask:backgroundTask];
backgroundTask = UIBackgroundTaskInvalid;
}];
//判断如果申请失败了, 返回
if (backgroundTask == UIBackgroundTaskInvalid) {
NSLog(@"beginground error");
return;
}
//已经成功向系统争取了一些后台运行时间, 实现一些逻辑, 如网络处理
//some code
}
当我们的任务已经完成, 如网络请求完成, 最好通知系统后台的逻辑已经完成了
//如, 网络处理结束
- (void)requestFinished
{
if (backgroundTask != UIBackgroundTaskInvalid) {
[[UIApplication sharedApplication] endBackgroundTask:backgroundTask];
backgroundTask = UIBackgroundTaskInvalid;
}
}
系统进入后台会自动调用Appdelegate中的- (void)applicationDidEnterBackground:(UIApplication *)application 这个方法, 我们要在这里手动调用RootController的startBackgroundTask方法
- (void)applicationDidEnterBackground:(UIApplication *)application
{
[rootController startBackgroundTask];
}
这样, 我们就可以在后台继续运行我们需要处理的逻辑了, 这里需要注意两点:
1、App进入后台最多只能运行10分钟,
2、如果超过了系统允许的时间没有调用endBackgroundTask:这个方法继续执行逻辑, App会被系统kill掉.
参考资料:
UIApplication
Class Reference
相关文章推荐
- Android导入一个工程时提示 Invalid project description的解决方法
- android 对多个手指触摸的处理
- Android 实现类似摇一摇功能
- 给你的移动网站加点料:推荐下载App,如果本地安装则直接打开本地App(Android/IOS)
- android工程常见问题处理之Unable to resolve target 'android-xx'
- NSArrayI insertObject:atIndex:]: unrecognized selector sent to instance 0x9c754c0 2013-06-19 00:16:0
- 在webapp中判断native app是否安装并直接打开
- 使用Cocos2d-x中的CCMenuItemToggle制作商店
- 关于ios XCode hangs at "Attaching to (app name)"
- android 拖放效果
- cocos2D中scheduleOnce的陷阱
- IOS 开发Xcode上传App发布流程
- android学习笔记(3)-android的布局管理
- android-Viewpager
- Android 锁屏原理,锁屏框架与锁屏开发
- ios 内置付费 iap
- Android Drawable文件分类及内存问题
- 实战ios Plist 读 写操作及修改 删除 排序
- swift mul node install
- struts2中,在request/session/application中访问或添加属性