UIApplication

本文深入探讨了iOS应用中的UIApplication实例的核心作用,包括事件处理、窗口管理、代理类的生命周期方法以及如何利用UIApplication实例进行操作。重点介绍了UIApplicationMain函数的作用,以及如何在代理类中实现不同状态的回调方法,如应用程序启动、关闭、进入后台等。同时,详细阐述了如何通过UIApplication实例控制应用的图标、网络状态显示、地图操作、邮件发送、电话拨打、短信发送和网址打开等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

UIApplication的核心作用是提供了iOS程序运行期间的控制和协作工作。

每一个程序在运行期必须有且仅有一个UIApplication(或则其子类)的一个实例。回想一下我在前面的文章“main函数研究”的文章中提到的main函数的代码,可以看出,在程序开始运行的时候,UIApplicationMain函数是程序进入点,这个函数做了很多工作,其中一个重要的工作就是创建一个UIApplication的单例实例。在你的代码中你,你可以通过调用[UIApplication sharedApplication]来得到这个单例实例的指针。

UIApplication的一个主要工作是处理用户事件,它会起一个队列,把所有用户事件都放入队列,逐个处理,在处理的时候,它会发送当前事件到一个合适的处理事件的目标控件。此外,UIApplication实例还维护一个在本应用中打开的window列表(UIWindow实例),这样它就可以接触应用中的任何一个UIView对象。UIApplication实例会被赋予一个代理对象,以处理应用程序的生命周期事件(比如程序启动和关闭)、系统事件(比如来电、记事项警告)等等。

新建一个任意类型的iOS应用工程,加入我们在Class Prefix输入是TC,我们可以看到工程中生成一个类:

TCAppDelegate :UIResponder <UIApplicationDelegate>

这里这个类的基类是UIResponder,和4.2以前生成的工程是不同的,以前是继承自NSObject。不论如何,本类实现了一个名叫UIApplicationDelegate的接口,这个表明这个类就是这个工程中UIApplication实例的代理类。

在main函数中,

 

@autoreleasepool {

       returnUIApplicationMain(argc, argv, nil,NSStringFromClass([TCAppDelegateclass]));

    }

这里传入了代理类到UIApplicationMain函数中,UIApplicationMain函数在生成唯一个UIApplication的时候就可以把代理类的实例指针告诉这个单例对象了。 

1、- (void)applicationWillResignActive:(UIApplication *)application

说明:当应用程序将要入非活动状态执行,在此期间,应用程序不接收消息或事件,比如来电话了

2、- (void)applicationDidBecomeActive:(UIApplication *)application

说明:当应用程序入活动状态执行,这个刚好跟上面那个方法相反

3、- (void)applicationDidEnterBackground:(UIApplication *)application

说明:当程序被推送到后台的时候调用。所以要设置后台继续运行,则在这个函数里面设置即可

4、- (void)applicationWillEnterForeground:(UIApplication *)application

说明:当程序从后台将要重新回到前台时候调用,这个刚好跟上面的那个方法相反。

5、- (void)applicationWillTerminate:(UIApplication *)application

说明:当程序将要退出是被调用,通常是用来保存数据和一些退出前的清理工作。这个需要要设置UIApplicationExitsOnSuspend的键值。

6、- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application

说明:iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,在终止前会执行这个方法,通常可以在这里进行内存清理工作防止程序被终止

7、- (void)applicationSignificantTimeChange:(UIApplication*)application

说明:当系统时间发生改变时执行

8、- (void)applicationDidFinishLaunching:(UIApplication*)application

说明:当程序载入后执行

9、- (void)application:(UIApplication)application willChangeStatusBarFrame:(CGRect)newStatusBarFrame

说明:当StatusBar框将要变化时执行

10、- (void)application:(UIApplication*)application willChangeStatusBarOrientation:

(UIInterfaceOrientation)newStatusBarOrientation

duration:(NSTimeInterval)duration

说明:当StatusBar框方向将要变化时执行

11、- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url

说明:当通过url执行

12、- (void)application:(UIApplication*)application didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation

说明:当StatusBar框方向变化完成后执行

13、- (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame

说明:当StatusBar框变化完成后执行

 

iPhone中的应用程序很容易受到打扰,比如一个来电可能导致应用程序失去焦点,如果这个时候接听了电话,那么应用程序会转到后台运行。还有很多其它类似的事件会导致iPhone应用程序失去焦点,在应用程序失去焦点前会调用委托类的applicationWillResignActive()方法,而应用程序再次获取到焦点的时候会调用applicationDidBecomeActive()方法。比如在运行应用程序的时候锁屏会调用委托类的applicationWillResignActive()方法,而当屏幕被解锁的时候,又会调用applicationDidBecomeActive()方法。

 

另外一个非常重要的方法就是applicationDidReceiveMemoryWarning(),因为iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,但在终止之前操作系统会通过先调用委托类的applicationDidReceiveMemoryWarning()方法警告应用程序,在UIApplication接收到这个事件后它会传递给委托类的applicationDidReceiveMemoryWarning()方法,委托类在这个方法内可以进行释放内存的操作以防止操作系统强制终止应用程序的运行。

下面是这个类的一些功能:

1.设置icon上的数字图标

    //设置主界面icon上的数字图标,在2.0中引进, 缺省为0

    [UIApplicationsharedApplication].applicationIconBadgeNumber = 4;

2.设置摇动手势的时候,是否支持redo,undo操作

    //摇动手势,是否支持redo undo操作。

   //3.0以后引进,缺省YES

    [UIApplicationsharedApplication].applicationSupportsShakeToEdit =YES;

3.判断程序运行状态

    //判断程序运行状态,在2.0以后引入

    /*

     UIApplicationStateActive,

     UIApplicationStateInactive,

     UIApplicationStateBackground

     */

   if([UIApplicationsharedApplication].applicationState ==UIApplicationStateInactive){

        NSLog(@"程序在运行状态");

    }

4.阻止屏幕变暗进入休眠状态

    //阻止屏幕变暗,慎重使用,缺省为no 2.0

    [UIApplicationsharedApplication].idleTimerDisabled =YES;

慎重使用本功能,因为非常耗电。

5.显示联网状态

    //显示联网标记 2.0

    [UIApplicationsharedApplication].networkActivityIndicatorVisible =YES;

6.在map上显示一个地址

   NSString* addressText =@"1 Infinite Loop, Cupertino, CA 95014";

   // URL encode the spaces

    addressText =  [addressTextstringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding];

   NSString* urlText = [NSStringstringWithFormat:@"http://maps.google.com/maps?q=%@", addressText];

    [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:urlText]];

7.发送电子邮件

   NSString *recipients =@"mailto:first@example.com?cc=second@example.com,third@example.com&subject=Hello from California!";

   NSString *body =@"&body=It is raining in sunny California!";

    NSString *email = [NSStringstringWithFormat:@"%@%@", recipients, body];

    email = [emailstringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];

    [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:email]];

8.打电话到一个号码

    // Call Google 411

    [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"tel://8004664411"]];

9.发送短信

    // Text to Google SMS

    [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"sms://466453"]];

10.打开一个网址

   // Lanuch any iPhone developers fav site

    [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"http://itunesconnect.apple.com"]]

### 关于 `UIApplication` 的用法及其在 iOS 18 中的变化 #### 背景介绍 自 iOS 系统发布以来,`UIApplication` 类一直是开发者用于管理应用生命周期的核心工具之一。它提供了访问全局对象的方法以及处理事件循环的功能。随着 iOS 不断更新迭代,苹果公司也在逐步调整该类的行为和接口设计。 #### iOS 18 中的关键变化 尽管官方文档未明确指出 `UIApplication` 在 iOS 18 中的具体改动,但从开发者的实践经验来看,以下几点值得注意: 1. **隐私与安全增强** 苹果公司在 iOS 18 继续加强了对用户数据保护的要求。对于通过 `sharedApplication` 获取实例并调用某些方法的情况,可能需要额外声明权限或遵循新的沙盒机制[^4]。这意味着任何涉及敏感操作(如网络请求、设备状态查询)的代码都需要重新评估合规性。 2. **弃用 API 替代方案** 随着时间推移,部分旧版 API 已经被标记为废弃。例如,在较早版本中提到过的 `wantsFullScreenLayout` 属性已被替代[^3]。虽然这并非直接影响 `UIApplication` 自身,但它反映了整个框架向现代化方向演进的趋势——鼓励开发者采用更灵活的设计模式来实现相同目标而不依赖特定属性配置。 3. **多窗口支持改进** 尽管全面意义上的 iPadOS 多任务特性是在后续版本才正式推出,但在 iOS 18 上已经可以看到一些铺垫工作。具体表现为当应用程序处于分屏或多任务环境下时,如何正确响应尺寸变更通知变得尤为重要。此时可以利用 `UIApplicationDelegate` 协议中的回调函数配合 `UIWindowSceneDelegate` 来适配不同场景下的行为逻辑。 4. **后台执行限制收紧** 对于那些试图绕过系统规定延长后台运行时间的应用程序来说,iOS 18 加大了监管力度。如果发现违规现象,则可能导致 AppStore 提交失败或者遭到下架处罚[^5]。因此建议仅限必要情况下申请适当类型的 Background Task 并严格控制其持续周期。 以下是展示如何获取单例对象并与之交互的一个简单例子: ```swift if let window = UIApplication.shared.windows.first { print("Main Window Frame:", window.frame) } ``` 此片段展示了怎样安全地访问当前活动窗口的信息而无需担心潜在崩溃风险。 --- ### 总结 综上所述,虽然表面上看似乎没有针对 `UIApplication` 做出特别显著的大规模重构动作;但实际上围绕安全性考量所做的种种微调却足以影响日常编码实践。务必密切关注最新指南说明以免无意间触犯政策底线造成不必要的麻烦。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值