PDA

View Full Version : about memory managing--dealloc & autorelease




Howiieque
Feb 14, 2009, 09:08 PM
// Controller.h

#import <Cocoa/Cocoa.h>


@interface Controller : NSObject {
IBOutlet NSImageView *imageView;
NSMutableArray * images;
int currentImage;
}
- (IBAction)nextImage:(id)sender;

@end

// Controller.m

#import "Controller.h"

@implementation Controller

- (void)awakeFromNib
{
NSBundle * mainBundle = [NSBundle mainBundle];
NSArray * imagePaths = [mainBundle pathsForResourcesOfType:@"jpg"
inDirectory:nil];
images = [[NSMutableArray alloc] init];
int count = [imagePaths count];
int i;
for (i = 0; i < count; i++) {
NSImage * image = [[NSImage alloc] initWithContentsOfFile:
[imagePaths objectAtIndex:i]];
[images addObject:image];
[image release];
}
currentImage = 0;
[imageView setImage:[images objectAtIndex:currentImage]];
}

- (IBAction)nextImage:(id)sender
{
currentImage++;
if (currentImage == [images count]) { // a
currentImage = 0;
}
[imageView setImage:[images objectAtIndex:currentImage]]; // b
}

@end
this example is from learning cocoa with objective-c 2nd. it is an application shows the picture in the bundle and has a button to show the next image.

My question is :
1 there is a instance variable that owned by this class. It is allocated in the awakefromnib method. Should I override the dealloc method to release this instance variable?
2 If I did so, it seems that the application did not invoke the dealloc method at all. I wonder why.
3 if i add a [images autorelease] in the awakefromnib method for later release, an error occurred when i hit the next button. That means the images has been released. but it should be added to the autoreleasepool and then get released when application terminate. things work properly in command line utility. why didn't it work here?



eddietr
Feb 15, 2009, 01:27 AM
My question is :
1 there is a instance variable that owned by this class. It is allocated in the awakefromnib method. Should I override the dealloc method to release this instance variable?


Yes


2 If I did so, it seems that the application did not invoke the dealloc method at all. I wonder why.


It may be because you are not releasing this controller properly. And so this controller is never dealloc'ed.


3 if i add a [images autorelease] in the awakefromnib method for later release, an error occurred when i hit the next button. That means the images has been released. but it should be added to the autoreleasepool and then get released when application terminate. things work properly in command line utility. why didn't it work here?

Remember that AppKit will create an autorelease pool for each event cycle. So if you autorelease an object in that context, it will be released before the next event cycle.

With a command line tool, you generally create and release your own autorelease pools. The template and most examples of this involve just one autorelease pool which is released right before the application terminates. This is probably why you think all autoreleases happen when any application terminates, which is not the case (especially when using AppKit)

Howiieque
Feb 15, 2009, 03:50 AM
Grate explanation. thank you.

but the answer to question 2. i am still not quit understand. Why it didn't release properly. how can i improve it. and other example provided by the book mentioned above seems that don't invoke the dealloc at all.

i also read:
Note that when an application terminates, objects may not be sent a dealloc message since the processís memory is automatically cleared on exitóit is more efficient simply to allow the operating system to clean up resources than to invoke all the memory management methods.--NSObject Class Reference
i am puzzled

Catfish_Man
Feb 15, 2009, 05:04 AM
If you need to do cleanup on application shutdown, use NSApplication's -applicationWillTerminate: delegate method rather than relying on dealloc. As an optimization, Cocoa won't always deallocate objects at shutdown since it knows they're about to go away anyway.

Howiieque
Feb 15, 2009, 08:04 AM
thank you. and your logo is pretty.

pstoehr
Feb 15, 2009, 08:36 AM
Hi,

have you turned garbagge collection on or is it still off?

Peter

eddietr
Feb 15, 2009, 09:55 AM
but the answer to question 2. i am still not quit understand. Why it didn't release properly. how can i improve it. and other example provided by the book mentioned above seems that don't invoke the dealloc at all.



I may have read too much into your question. I assumed you were done with your controller and wondering why the dealloc was not being called.

If you use your controller for the entire lifetime of your application then you may never get the dealloc call. Because when the application terminates, it doesn't go through and dealloc every object because that would be a waste of time. Once the application is terminated, the OS is going to reclaim all it's memory anyway.

But, on the other hand, if your controller is not supposed to last the whole lifecycle of the application, then you can release it when it is not needed. Then when the release count is 0, your controller will get the dealloc message which in turn will release other objects.

Hope that makes sense?

Howiieque
Feb 16, 2009, 06:22 PM
thank you so much. it really makes sense.:)