Search code examples
swiftsprite-kitswift3weak-referencesretain-cycle

Knowing where retain cycles are and removing them


I was wondering if there was an easy way (or at least a way) to find out where retain cycles exist in your program. Also, if I then know where these retain cycles exist, depending on their types (e.g. variable or closure), how do I make them weak. I need to stop all retain cycles with self (my GameScene) so that it deallocates when I don't need it anymore and I want to restart it.

Any tips, advice, answers, and feedback would be greatly appreciated (and providing specific code and examples would be preferred). Thank you.

Edit: @Sweeper's answer was just what I was looking for. If you're having the same issue his answer will help. Thanks @Sweeper!


Solution

  • If you are using Xcode 8 or above, you can use the memory graph thingy to see what object holds a reference to what object.

    To see the memory graph, first build and run your app with Xcode. When you want to check whether all the instances you created are discarded properly, go to this tab on the left pane:

    enter image description here

    Then press the button on the right there:

    enter image description here

    After that, select the bottom-most option - View Memory Graph Hierarchy:

    enter image description here

    Now it will show you all the objects that are in memory:

    enter image description here

    In my case, I have a GameSystem object, 6 ButtonNode objects and a few others. You'll notice that there is a little ! beside the GameSystem object. That means this object is leaked. Also, GameScene should not be in memory anymore because the current scene is TitleScene. Let's see what is retaining it by clicking on the instance:

    enter image description here

    Now you can clearly see that it is retained by a closure!

    That is how you use the memory graph to see where you should put weak-references and avoid retain cycles.