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

Unowned references

You can use unowned references when you can guarantee that the owner of another object will never exist when the reference is deallocated. Let's look at the following example:

class CreditCard {
let number: String
let expiry: String
unowned let owner: Person

init(owner: Person) {
self.owner = owner
self.number = "XXXXXXXXXXXXXXXX"
self.expiry = "XX/YY"
}
}

class Person {
let name: String
var cards: [CreditCard] = []

init(name: String) {
self.name = name
}
}

In this example, one person can have many credit cards. Each card needs to have an owner, which is immutable.

Let's look that how to use such an API:

let me = Person(name: "John Smith")
let card = CreditCard(owner: me)
let otherCard = CreditCard(owner: me)
me.cards = [card, otherCard]

In this example, me has two credit cards; each card has a back reference to its owner. In this particular case, we can always guarantee that the owner will never be deallocated before the cards. A CreditCard without an owner doesn't make any sense, and if we're trying to access the owner property of such a card, our program is probably not sane anymore. The behavior to notice here is that, compared to the weak modifier, the owner property on the CreditCard is not required to be an optional.

In this particular example, if we omitted the unowned qualifier, when there were no references left to Person, the back references from the cards would keep the object alive, effectively leaking both the credit cards and the owner of the cards.

Now that we've covered the semantics of memory ownership, we can dive deeply into the memory management and debugging tools that come with Xcode.

主站蜘蛛池模板: 安阳县| 郸城县| 金秀| 湟源县| 西青区| 乡宁县| 宁安市| 平果县| 龙岩市| 高阳县| 西昌市| 信丰县| 长治市| 剑川县| 句容市| 留坝县| 罗甸县| 尚志市| 凤翔县| 东辽县| 信丰县| 红原县| 遂平县| 乌什县| 宝兴县| 高淳县| 阿克陶县| 西充县| 阿拉善左旗| 通许县| 丰顺县| 大理市| 台前县| 青浦区| 上饶县| 罗山县| 威远县| 肥城市| 怀远县| 界首市| 卓资县|