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

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.

主站蜘蛛池模板: 锦屏县| 确山县| 左权县| 南平市| 运城市| 东兰县| 通城县| 张北县| 中牟县| 松原市| 三台县| 科技| 南部县| 奉贤区| 额尔古纳市| 江山市| 弋阳县| 石景山区| 临泉县| 广安市| 莱西市| 兰溪市| 壤塘县| 包头市| 偃师市| 西平县| 德保县| 八宿县| 依兰县| 响水县| 五莲县| 宜州市| 黄平县| 那曲县| 湖口县| 新干县| 博兴县| 南康市| 桃园市| 云南省| 明水县|