Re: NSWindowController subclasses, and retain cycles
Re: NSWindowController subclasses, and retain cycles
- Subject: Re: NSWindowController subclasses, and retain cycles
- From: Fritz Anderson <email@hidden>
- Date: Thu, 24 May 2012 10:21:28 -0500
On 24 May 2012, at 9:26 AM, Jonathan Taylor wrote:
> - I have a window controller subclass (and associated window) A, and a separate window controller subclass (and associated window) B. B contains a property, designated 'retain', that keeps a pointer to A. B is programatically closed first, and later on A is programatically closed
> - I believe that I am correctly balancing retain/release for A.
> - I believe I am doing the same for B.
>
> 1. If I do not set B's pointer to A, both A and B are deallocated correctly
> 2. If instead I set B's pointer to A, but reset it to nil just before B is closed, both A and B are deallocated correctly
> 3. If instead B still has a live pointer to A when B is closed, this should be autoreleased by the runtime, which it is. However, A never gets deallocated.
Why do you believe that a retain @property does not always require a release (set to nil)? The autorelease you seem to have detected was sent by a completely different chain of execution to balance a retain made in that chain. The operating system does not magically know that you're done with B's retention of A; you have to balance your own retains with your own releases. (2) works because it is correct.
— F
_______________________________________________
Cocoa-dev mailing list (email@hidden)
Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden