iOSapp 进入后台后获取更多的时间操作
2015-11-27 10:46
507 查看
转载自:http://blog.csdn.net/happyhell/article/details/8974765
切克闹 代码实现:
@interface AppDelegate :
UIResponder <UIApplicationDelegate,WXApiDelegate,UIAlertViewDelegate>
{
__blockUIBackgroundTaskIdentifier _bgTask;
}
。。。
.m中实现:
- (void)backgroundHandler
{
UIApplication* app = [UIApplicationsharedApplication];
if (_bgTask !=UIBackgroundTaskInvalid){
[app endBackgroundTask:_bgTask];
_bgTask =UIBackgroundTaskInvalid;
}
_bgTask = [appbeginBackgroundTaskWithExpirationHandler:^{
[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
{
[selfbackgroundHandler];
}
- (void)applicationDidBecomeActive:(UIApplication *)application
{
//notification
application.applicationIconBadgeNumber =0;
[application cancelAllLocalNotifications];
if (_bgTask !=UIBackgroundTaskInvalid){
[application endBackgroundTask:_bgTask];
_bgTask =UIBackgroundTaskInvalid;
}
if (![[GNXMPPEnginesharedInstance]
havConnect]){
[[GNXMPPEnginesharedInstance]
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>
{
__blockUIBackgroundTaskIdentifier _bgTask;
}
。。。
.m中实现:
- (void)backgroundHandler
{
UIApplication* app = [UIApplicationsharedApplication];
if (_bgTask !=UIBackgroundTaskInvalid){
[app endBackgroundTask:_bgTask];
_bgTask =UIBackgroundTaskInvalid;
}
_bgTask = [appbeginBackgroundTaskWithExpirationHandler:^{
[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
{
[selfbackgroundHandler];
}
- (void)applicationDidBecomeActive:(UIApplication *)application
{
//notification
application.applicationIconBadgeNumber =0;
[application cancelAllLocalNotifications];
if (_bgTask !=UIBackgroundTaskInvalid){
[application endBackgroundTask:_bgTask];
_bgTask =UIBackgroundTaskInvalid;
}
if (![[GNXMPPEnginesharedInstance]
havConnect]){
[[GNXMPPEnginesharedInstance]
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
相关文章推荐
- JS调用android
- android 5.0及以上,seekbar thumb 透明效果出现父布局背景颜色的解决方法
- 實作解析:微信開發重點摘要 (2) - 用戶唯一識別碼與網頁存取授權碼
- android 休眠唤醒机制分析(一)
- Android学习笔记(四):Volley的使用
- android studio里面的svn基本使用
- android中shape、selector、color
- 行为驱动开发iOS
- Android防止重复点击深入
- iOS开发日记49-详解定位CLLocation
- org.springframework.context.ApplicationContextAware
- Jenkins+ Gradle +Lint对Android工程源码进行静态代码分析
- 移动APP切图术语解读:什么是@1x @2x和@3x
- mybatis xml文件 id冲突错误 findUserIDById is ambiguous in Mapped Statements collection
- Android 控件布局常用属性
- Android入门:增删改查通讯录
- 微信支付Demo下载(完整文档+使用说明)
- Android Studio 配置Android Annotation
- Android imageview帧动画 监听结束
- Mac下利用safari调试 Cordova的WebApp