官术网_书友最值得收藏!

Dangling references

Now that we've seen the powerful weak and unowned modifiers and have regained control over our memory management, we are thrilled to use it everywhere. That is, until we see a crash in the form of the following:

Fatal error: Attempted to read an unowned reference but object 0x10132c0f0 was already deallocated. 

This is the same issue as the, which the dangling pointer one that we saw earlier in this chapter.

Let's reuse the example, as follows:

func getCard() -> Card {
let batman = Person(name: "Batman")
let card = Card(batman)
batman.cards.append(card)
return card
}

let card = getCard()
print("\(card.owner.name)")

In this code, we explicitly return a card, but the owner of this card is not in the memory anymore, as it was properly deallocated after we exited the scope. Let's break it down, line by line, and try to get an idea of the counts, as shown in the following table:

With this in mind, we can now see why the program crashes, as there's nothing left to retain the owner of the card.

This can be seen as unsafe, but it should not be. This example, while valid, is a perfect example where the relationship is unowned because it can't be anything else. weak would have forced us to write the owner as an optional, which is incorrect, and using a strong relationship ultimately leads to cycles and leaks being retained.

To overcome this issue, we have to re-evaluate our code and ensure that we never return a card disassociated from its owner. The unowned references preserve the semantics of your program, while ensuring that the memory management is sane.

主站蜘蛛池模板: 驻马店市| 巴林右旗| 开阳县| 县级市| 容城县| 河东区| 娱乐| 九龙坡区| 凌海市| 叶城县| 西峡县| 寿光市| 读书| 南通市| 化隆| 德格县| 庆安县| 楚雄市| 石林| 沾化县| 马边| 白山市| 安龙县| 土默特右旗| 航空| 永川市| 叙永县| 博白县| 大连市| 奉新县| 那坡县| 綦江县| 清远市| 兴文县| 资溪县| 桦川县| 朔州市| 察哈| 通道| 孙吴县| 辽宁省|