问题
When application enters in background running state, how much dirty memory usages is good to go. In apple video it's mentioned that the dirty memory should be reduced as much as we can.
But in my App, I am using navigation controller to push and pop views. After moving from about 20 different pages, the dirty memory usages reaches 30 MB or so.
Also on "dismissModalViewControllerAnimated" and "popViewControllerAnimated", dealloc is not called.
I have two doubts:
- With how much dirty memory is acceptable to go live?
- What is the alternate of navigation controller to support back button?
Thanks in advance.
回答1:
You might still have your UIViewControllers still retained if dealloc isn't being called.
Perhaps are you setting delegates or other classes in these UIViewControllers that retained and referenced back up the tree (circular references).
A way you can debug this is to overload retain and release in your UIViewController and set a break point and log the retainCount.
Here is a magic snippet I leave running around that helps me a ton when I can't figure out why I'm still retaining something.
- (id)retain
{
NSLog(@"retain \t%s \tretainCount: %i", __PRETTY_FUNCTION__ , [self retainCount]);
return [super retain];
}
- (void)release
{
NSLog(@"release \t%s \tretainCount: %i", __PRETTY_FUNCTION__ , [self retainCount]);
[super release];
}
- (id)autorelease
{
NSLog(@"autorelease \t%s \tretainCount: %i", __PRETTY_FUNCTION__ , [self retainCount]);
return [super autorelease];
}
__PRETTY_FUNCTION__
is a special hidden macro in CLang that gives a pretty Objective-C function name as a char array.
回答2:
- When an iOS starts running out of memory it tries to kill the background processes that are using the most memory. So while there's no absolute good number, minimising how much memory you use is a good idea. Leaving it at 30Mb is tantamount to guaranteeing that your app will be killed
- Unless you want to change your UI there is no need to use anything other that a
UINavigationController
to deal with your back button. I think the problem here is that ifdealloc
is not called on a pop or dismiss, you have a memory leak
Almost all view controllers have data that is effectively cached and can be regenerated when the app returns to the foreground. Think of the data that you release when you get a memory warning when the app is running. (You are responding to memory warnings, right?) It's that stuff that should be released when you go into the background.
来源:https://stackoverflow.com/questions/3185626/ios4-fast-context-switching