I thought I understood it clearly from this question --> Should IBOutlets be strong or weak under ARC? but I recently had a discussion which left me totally confused. Can someone just confirm if the following is correct? (if this is a duplicate I didn't mean to break any rules.. just need clarification as I can understand diagrams better than words..)
Under ARC (MacOSx)
- view1 = strong
- MainView = weak (In WindowControllerA)
- MainView = strong (In ViewControllerB)
- view2 = strong
- view3 = weak (In ViewcontrollerB)
- view3 = strong (In ViewControllerC)
If this is correct then can someone confirm please..
In the diagram above, we have a windowControllerA that is on the screen. In windowControllerA's view, there are 2 NSViews. view1 belongs to the windowController, but mainView belongs to the view of the instianciated viewController, ViewControllerB.
ViewControllerB also contains 2 views within its mainView. View2 is owned by viewControllerB while view3 belongs to another instanced viewController, ViewControllerC.
ViewController C has one view which it owns.
Most outlets for subviews don't need to be strong references because, after all, they're subviews loaded as part of a view hierarchy. As long as the top-level view exists, and as long as you don't go removing the subviews from their parents, the subviews in the view hierarchy will be retained by their parents for the lifetime of the top-level view.
In the days before ARC, some people were happy to rely on the view hierarchy to retain their views for them and so set their outlet properties to assign
. Others didn't like the idea that a hiccup in the view hierarchy could leave them with a handful of dangling pointers, and so set their properties to retain
. ARC gives us zeroing weak references, so that your outlets will be set to nil
if the objects they point to are deallocated, and that makes using weak references for outlets seem a lot safer. On the other hand, if you want to maintain a reference to a view even if the view hierarchy that contains is is deallocated, you should set that reference to strong
.
Since your view controller is responsible for the view hierarchy it manages (i.e. "owns"), it should have a strong reference to the top-level view. You don't need to worry too much about this, as the view
property of any UIViewController-derived view controller is set to retain
(i.e. strong
).
As long as I understood this "All the top-level objects should be strong. And subviews should be weak". So in that case view2 should be weak also
- view1 = strong
- MainView = weak (In WindowControllerA)
- MainView = strong (In ViewControllerB)
- view2 = weak (since mainview already hold it)
- view3 = weak (In ViewcontrollerB)
- view3 = strong (In ViewControllerC)
So many discussions about the weak vs. strong reference to .xib objects in the File Owner's IBOutlets --- and it seems EVERYONE is only concerned about views and subviews.
Subviews are owned by their superviews, and so as long as you do not tear down view hierarchy programmatically (and take responsibility for view ownership while at it) you don't need to worry too much.
BUT --- what about all those other objects you create in .xibs regularly, like NSArrayControllers and those root-level UI items that are NOT views, like Windows, Panels, Alerts, and so on --- should THEY be referenced strong? weak?
I really need some low level explanation of how xibs work. When an object is a "File's owner" and loads its nib file, What gets loaded and initialized? Just objects to which you have IBOutlets? Every top-level object?
Who owns all these root-level objects? After all the controller who loads the nib (and is normally the "File's Owner" owns the .xib --- but does this mean it owns (automatically) the root level objects in the nib?
If so --- what is the difference if you have a weak IBOutlet reference to a .xib object, or strong, or none at all ---- you're still "File's Owner" for that object,
Some better explanation will do.