swift内存管理中的引用计数

swift内存管理中的引用计数,第1张

概述在swift中,每一个对象都有生命周期,当生命周期结束会调用deinit()函数进行释放内存空间。 观察这一段代码: class Person{ var name: String var pet: Pet? init(name: String){ self.name = name print("Person"

在swift中,每一个对象都有生命周期,当生命周期结束会调用deinit()函数进行释放内存空间。

观察这一段代码:

class Person{        var name: String    var pet: Pet?        init(name: String){        self.name = name        print("Person",name,"is initialized")    }        init(name: String,petname: String){        self.name = name        self.pet = Pet(name: petname)        print("Person","is initialized")    }        deinit{        print("Person","is deinitialized!")    }}class Pet{        var name: String    init(name: String){        self.name = name;        print("Pet","is initialized")    }        deinit{        print("Pet","is deinitialized!")    }}

这段代码创建了两个类,分别是Person类和Pet类,每个类中都有init方法进行创建对象和deinit方法来释放内存空间,其中Person类中有两个init方法,分别对应着是否包含Pet类的名称。

当我们调用这两个方法:

var sNow: Person? = Person(name: "sNow",petname: "wolf")sNow = nil

两步的执行结果是:

Pet wolf is initializedPerson sNow is initializedPerson sNow is deinitialized!Pet wolf is deinitialized!

会发现在创建sNow这个对象的时候调用的是第二个init方法,在这个方法中会创建一个新的Pet对象,因此会首先打印出Pet wolf is initialized然后是Person sNow is initialized。当对sNow对象进行内存释放的时候,将nil赋给这个对象,那么会释放sNow这个内存空间,同时也会释放wolf这个内存空间。

但是如果我们调用第一种init方法的时候我们会发现:

var sNow: Person? = Person(name: "sNow")var wolf: Pet? = Pet(name: "wolf")sNow?.pet = wolfsNow = nilwolf = nil

我们首先创建了一个sNow对象,之后又创建了一个wolf对象,然后将wolf添加到sNow对象中去,但是当我们对这sNow这个对象进行内存释放的时候会发现:

Person sNow is initializedPet wolf is initializedPerson sNow is deinitialized!

仅仅只有sNow的内存空间被释放了,但是wolf的内存空间并没有被释放,这里就和swift内存管理中的引用计数有关了:

当我们创建了sNow这个对象之后,我们就为它开辟了一个内存空间,命名为a,这时候sNow这个对象引用了这片内存空间,这片内存空间的引用计数就是1,

同样地当我们创建了wolf这个对象之后,我们就为它开辟了一个内存空间,命名为b,这时候wolf这个对象引用了这片内存空间,这片内存空间的引用计数就是1,

当我们将sNow?.pet = wolf之后,那么sNow中的一个属性也指向了创建wolf这个对象的内存空间,那么这篇内存空间的引用计数就是2.

当我们对sNow = nil进行内存空间的释放,那么内存空间a的引用计数就为0了,同时内存空间b的引用计数就为1了。

当系统发现一篇内存空间的引用计数为0,那么,系统就会释放这片内存空间,此时内存空间a就被释放了。

但是内存空间b的引用计数为1,系统不会进行自动的内存释放。只有当我们进行:

wolf = nil

*** 作之后,这片内存空间b才会被释放。

同样地对于这样代码:

import UIKitclass Person{        var name: String        init(name: String){        self.name = name        print("Person","is being deinitialized!")    }}var person1: Person? = Person(name: "liuyubobobo")var person2: Person? = person1var person3: Person? = person1

那么person1的内存空间的引用计数为3,如果释放这片内存空间的话,需要将三个对象都为nil

如果仅仅是将person1=nil的话,并不会释放这一片内存空间。

总结

以上是内存溢出为你收集整理的swift内存管理中的引用计数全部内容,希望文章能够帮你解决swift内存管理中的引用计数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1090188.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存