zoukankan      html  css  js  c++  java
  • iOS 进入后台的处理

    当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(@"background error");
      return;
      }
      
      //已经成功向系统争取了一些后台运行时间, 实现一些逻辑, 如网络处理
      //do something
    }

    当我们的任务已经完成, 如网络请求完成, 最好通知系统后台的逻辑已经完成了

    //如, 网络处理结束
    - (void)requestFinished
    {
      if (backgroundTask != UIBackgroundTaskInvalid) {
      [[UIApplication sharedApplication] endBackgroundTask:backgroundTask];
    backgroundTask = UIBackgroundTaskInvalid;
      }
    }

        系统进入后台会自动调用Appdelegate中的- (void)applicationDidEnterBackground:(UIApplication *)application 这个方法, 我们要在这里手动调用RootControllerstartBackgroundTask方法

    - (void)applicationDidEnterBackground:(UIApplication *)application
    {
      [rootController startBackgroundTask];
    }

    这样, 我们就可以在后台继续运行我们需要处理的逻辑了, 这里需要注意两点:
    1、App进入后台最多只能运行10分钟,
    2、如果超过了系统允许的时间没有调用endBackgroundTask:这个方法继续执行逻辑, App会被系统kill掉.

    参考资料:
    UIApplication Class Reference

    进入后台获取更多的运行时间

  • 相关阅读:
    素数筛选法
    一种美-无法言语
    动态规划-钢条切割问题
    动态规划《开篇》
    判断两序列是否为同一棵二叉搜索树
    C++字符串转化为数字的库函数
    C++字符串类型和数字之间的转换
    遍历二叉树的非递归实现
    关于二叉树的问题1-已知前序,中序求后序遍历
    获取回车事件
  • 原文地址:https://www.cnblogs.com/suenihy/p/3520639.html
Copyright © 2011-2022 走看看