【iOS】swift 让程序挂起后,能在后台继续运行任务

1,程序的挂起和退出

由于iOS设备资源有限。当用户点击了home键,或者另一个应用程序启动了。那么原先那个程序便进入后台被挂起,不是退出,只是停止执行代码,同时它的内存被锁定。当应用程序恢复时,它会从停止的位置重新开始。

2,如下特殊的应用程序可以在后台长时间的运行
(1)在后台播放音频的应用程序可以在任意长的时间内保持活动状态,直到用户开始从另一个App播放音乐为止。
(2)在后台跟踪用户位置的应用程序可以运行任意长的时间。
(3)诸如Skype之类的 网络协议电话(VoIP)应用程序可以定期运行,以向服务器签到,但除非正在进行通话,否则不允许不加限制地运行。

3,申请程序在后台短时运行
(1)除了上述的特殊应用,App进入后台时便自动挂起。但我们可以申请该应用在后台能短时间运行。但这个时长不能超过10分钟。
(2)后台短时运行的存在是为了让应用程序能够完成一个需要长时间运行的过程。比如将大型文件写会磁盘,完成下载,或者像即时通讯软件给对方发照片(选择发送后,即使进入后台,也能继续发送)。
(3)在10分钟结束时,应用程序必须告诉OS,它已经完成或者被终止。
(4)注意:并不能保证用于后台任务的额外时间是连续的,这些时间可能会被分为很多段,以延长 电池寿命。

4,通过样例演示如何在后台运行任务
主页面上通过定时器不断的打印出数字。还有个开关按钮,切换选择程序进入后台后是否继续运行。
开关开启时,按home键退出应用,过一会儿再回来,可以发现数字在后台还会一直 打印数字。开关关闭,程序进入后台即挂起,不会再打印数字。
这个需要使用真机测试,模拟器比较特殊,不管什么情况程序进入后台都会一直运行)
   技术分享   技术分享
--- ViewController.swift ---
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
import  UIKit
 
class  ViewController UIViewController  {
     
     @IBOutlet  weak  var  textView:  UITextView !
     
     @IBOutlet  weak  var  mySwitch:  UISwitch !
     
     var  i=0
     
     override  func  viewDidLoad() {
         super .viewDidLoad()
         
         //创建定时任务
         _ =  NSTimer .scheduledTimerWithTimeInterval(1,
             target: self ,selector: Selector ( "tickDown" ),
             userInfo: nil ,repeats: true )
     }
     
     //计时器每秒触发事件
     func  tickDown() {
         textView.text! +=  "\(i++) "
     }
    
     override  func  didReceiveMemoryWarning() {
         super .didReceiveMemoryWarning()
     }
}


--- AppDelegate.swift ---

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import  UIKit
 
@UIApplicationMain
class  AppDelegate UIResponder UIApplicationDelegate  {
 
     var  window:  UIWindow ?
     
     //后台任务
     var  backgroundTask: UIBackgroundTaskIdentifier ! =  nil
 
 
     func  application(application:  UIApplication ,
         didFinishLaunchingWithOptions launchOptions: [ NSObject AnyObject ]?) ->  Bool  {
         return  true
     }
 
     func  applicationWillResignActive(application:  UIApplication ) {
     }
 
     func  applicationDidEnterBackground(application:  UIApplication ) {
         let  controller: ViewController  self .window?.rootViewController  as ViewController
         controller.textView.text! +=  "进入后台 "
         
         //如果已存在后台任务,先将其设为完成
         if  self .backgroundTask !=  nil  {
             application.endBackgroundTask( self .backgroundTask)
             self .backgroundTask =  UIBackgroundTaskInvalid
         }
         
         //如果要后台运行
         if  controller.mySwitch.on {
             //注册后台任务
             self .backgroundTask = application.beginBackgroundTaskWithExpirationHandler({
                 () ->  Void  in
                 //如果没有调用endBackgroundTask,时间耗尽时应用程序将被终止
                 application.endBackgroundTask( self .backgroundTask)
                 self .backgroundTask =  UIBackgroundTaskInvalid
             })
         }
     }
 
     func  applicationWillEnterForeground(application:  UIApplication ) {
     }
 
     func  applicationDidBecomeActive(application:  UIApplication ) {
     }
 
     func  applicationWillTerminate(application:  UIApplication ) {
     }
}

转载于:https://www.cnblogs.com/melons/p/5791989.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS 的开发中,可以通过以下两种方式来让应用在一定时长后后台关闭: 1. 使用 Timer 可以在应用启动后使用 Timer 定时器来计算应用运行的时长,当运行时间超过设定的时间后,就可以通过调用 UIApplication 的 `beginBackgroundTask(withName:expirationHandler:)` 方法来申请后台任务,然后在后台任务中调用 `UIApplication.shared.perform(#selector(NSXPCConnection.suspend))` 方法来让应用进入后台并关闭。 示例代码: ``` private var timer: Timer? private var backgroundTask: UIBackgroundTaskIdentifier = .invalid func startTimer() { timer = Timer.scheduledTimer(withTimeInterval: 60.0, repeats: true) { [weak self] _ in guard let self = self else { return } let runTime = Date().timeIntervalSince(self.startTime) if runTime > 3600 { // 超过1小时 self.stopTimer() self.backgroundTask = UIApplication.shared.beginBackgroundTask(withName: "CloseAppInBackground") { self.endBackgroundTask() } UIApplication.shared.perform(#selector(NSXPCConnection.suspend)) } } } func stopTimer() { timer?.invalidate() timer = nil } func endBackgroundTask() { UIApplication.shared.endBackgroundTask(backgroundTask) backgroundTask = .invalid } ``` 2. 使用 DispatchAfter 可以在应用启动后使用 GCD 的 `DispatchQueue.asyncAfter(deadline:)` 方法来延迟一定时间后执行关闭应用的操作,然后在应用进入后台时调用 `UIApplication.shared.perform(#selector(NSXPCConnection.suspend))` 方法来让应用进入后台并关闭。 示例代码: ``` private var closeAppWorkItem: DispatchWorkItem? func scheduleCloseApp() { let deadline = DispatchTime.now() + 3600 closeAppWorkItem = DispatchWorkItem { UIApplication.shared.perform(#selector(NSXPCConnection.suspend)) } DispatchQueue.main.asyncAfter(deadline: deadline, execute: closeAppWorkItem!) } func cancelCloseApp() { closeAppWorkItem?.cancel() } ``` 以上是两种让应用在一定时长后后台关闭的方法,开发者可以根据自己的需求选择合适的方法来实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值