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

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.

主站蜘蛛池模板: 塔城市| 青海省| 合川市| 山东| 平远县| 广饶县| 昌黎县| 墨脱县| 辉南县| 城步| 松滋市| 财经| 临沧市| 河间市| 利津县| 沈丘县| 南漳县| 噶尔县| 正阳县| 广饶县| 兴和县| 浮山县| 喜德县| 即墨市| 西贡区| 洞口县| 化隆| 汝南县| 桐梓县| 唐山市| 定结县| 高要市| 和平县| 辽中县| 沛县| 化隆| 宁强县| 登封市| 利辛县| 图木舒克市| 洮南市|