ByAI:iOS 生命周期:AppDelegate 与 SceneDelegate 中的 `willEnterForeground` 方法解析

34 阅读2分钟

背景

苹果在 iOS 18.4 及后续版本中要求应用逐步迁移到基于场景的生命周期(Scene-Based Lifecycle) 。若未适配,系统会提示警告,未来版本甚至可能禁止未适配的应用启动。本文重点解析 applicationWillEnterForeground(AppDelegate)与 sceneWillEnterForeground(SceneDelegate)的差异。


核心差异

1. 作用范围不同

  • AppDelegate 的 applicationWillEnterForeground
    当整个应用从后台进入前台时触发,仅调用一次,适用于全局逻辑(如恢复网络连接、更新全局数据)。

    // AppDelegate.swift
    func applicationWillEnterForeground(_ application: UIApplication) {
        print("App 即将进入前台(全局)")
    }
    
  • SceneDelegate 的 sceneWillEnterForeground
    当单个场景(Scene)进入前台时触发。若应用支持多窗口(如 iPad 分屏),每个场景会独立调用一次,需避免重复执行全局逻辑。

    // SceneDelegate.swift
    func sceneWillEnterForeground(_ scene: UIScene) {
        print("场景即将进入前台(单场景)")
    }
    

2. 冷启动时的行为差异

  • 冷启动(首次启动应用)时

    • applicationWillEnterForeground 不会触发(应用尚未进入后台)。
    • sceneWillEnterForeground 会触发(场景初始化后即视为进入前台)。

迁移注意事项

  1. 避免代码重复执行
    若将 applicationWillEnterForeground 的代码迁移到 sceneWillEnterForeground,需确保多窗口场景下逻辑仅执行一次(例如通过单例或状态标记)。

  2. 区分全局与场景逻辑

    • 全局逻辑(如用户登录状态检查)建议仍在 AppDelegate 中处理。
    • 场景相关逻辑(如界面刷新)迁移到 SceneDelegate
  3. 无需紧急适配
    AppDelegate 目前仍被支持,但建议逐步迁移以适应未来强制要求。


测试与验证

  • 官方文档参考
    查阅 Apple UIKit 文档,确保实现符合最新规范。
  • 模拟多场景环境
    在 iPad 或支持多窗口的设备上测试,验证多场景下的逻辑正确性。

总结

方法触发条件调用次数适用场景
applicationWillEnterForeground应用全局进入前台一次全局状态恢复
sceneWillEnterForeground单个场景进入前台每个场景一次场景相关界面更新