views:

1676

answers:

3

Hi,

The applicationWillTerminate delegate method is not getting called in iOS 4.0 When I hit the Home button I am seeing the applicationWillResignActive and applicationDidEnterBackground delegate methods getting called.

 - (void)applicationWillResignActive:(UIApplication *)application
{
  NSLog(@"Application Did Resign Active");
}

- (void)applicationDidEnterBackground:(UIApplication *)application
{
  NSLog(@"Application Did Enter Background");
}

And when I double Tap the Home button and again launch the Application the i find the applicationWillEnterForeground and applicationDidBecomeActive delegate methods are getting called.

 - (void)applicationWillEnterForeground:(UIApplication *)application
{
  NSLog(@"Application Will Enter Background");
}



- (void)applicationDidBecomeActive:(UIApplication *)application
{
  NSLog(@"Application Did Become Active");
}

But I want to know when the applicationWillTerminate delegate method will be called , where I do some DB/file backup routines.

- (void)applicationWillTerminate:(UIApplication *)application{

}

I even tried to hit the minus sign and deleted the App running in the Background , but still it did not call any delegate method.

Any Ideas ???

+6  A: 

From the iPhone Application Programming Guide:

Even if you develop your application using iPhone SDK 4 and later, you must still be prepared for your application to be terminated. If memory becomes constrained, the system might remove applications from memory in order to make more room. If your application is currently suspended, the system removes your application from memory without any notice. However, if your application is currently running in the background, the system does call the applicationWillTerminate: method of the application delegate. Your application cannot request additional background execution time from this method.

So yes, applicationWillTerminate: will generally not be called very often in iOS 4. If you have to save data, you should do so in both applicationWillTerminate: and applicationDidEnterBackground:.

Ole Begemann
Around minute 22 of the video quoted by falconcreek, it's said that only background running apps that are killed via the red minus icon get the benefit of a applicationWillTerminate: call before being killed. Suspended ones die right away. It's listed under 'Termination', and not made 100% clear, but it sounds like this applies to system termination and user initiated termination via the minus sign.
Joost Schuur
+2  A: 

The WWDC 2010 Session 105 - Adopting Multitasking on iPhone OS, Part 1 Video explains the application state transitions extremely well. WWDC 2010 Session Videos

falconcreek
+1  A: 

I got one solution for terminating apps when user hits the Home button in iOS4. This will call the applicationWillTerminate delegate method instead of entering into background process.

  1. Open your info.plist file
  2. Add The Key UIApplicationExitsOnSuspend
  3. Set the new key to YES
Biranchi
That will immediately exit your application instead of just suspending it. So when the user relaunches the app, it will have to start up all over again, eliminating the benefit of fast application switching. In general, using UIApplicationExitsOnSuspend is discouraged unless your application really needs to exit (http://tinyurl.com/2fgkf5p).
Brian