时间:2021-05-02
在swift中,每一个对象都有生命周期,当生命周期结束会调用deinit()函数进行释放内存空间。
观察这一段代码:
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 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", name, "is initialized") } deinit{ print("Person", name, "is deinitialized!") } } class Pet{ var name: String init(name: String){ self.name = name; print("Pet", name, "is initialized") } deinit{ print("Pet", name, "is deinitialized!") } }这段代码创建了两个类,分别是Person类和Pet类,每个类中都有init方法进行创建对象和deinit方法来释放内存空间,其中Person类中有两个init方法,分别对应着是否包含Pet类的名称。
当我们调用这两个方法:
? 1 2 var snow: Person? = Person(name: "snow", petName: "wolf") snow = nil两步的执行结果是:
? 1 2 3 4 Pet wolf is initialized Person snow is initialized Person snow is deinitialized! Pet wolf is deinitialized!会发现在创建snow这个对象的时候调用的是第二个init方法,在这个方法中会创建一个新的Pet对象,因此会首先打印出Pet wolf is initialized然后是Person snow is initialized。当对snow对象进行内存释放的时候,将nil赋给这个对象,那么会释放snow这个内存空间,同时也会释放wolf这个内存空间。
但是如果我们调用第一种init方法的时候我们会发现:
? 1 2 3 4 5 6 7 var snow: Person? = Person(name: "snow") var wolf: Pet? = Pet(name: "wolf") snow?.pet = wolf snow = nil wolf = nil我们首先创建了一个snow对象,之后又创建了一个wolf对象,然后将wolf添加到snow对象中去,但是当我们对这snow这个对象进行内存释放的时候会发现:
? 1 2 3 Person snow is initialized Pet wolf is initialized Person 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,系统不会进行自动的内存释放。只有当我们进行:
? 1 wolf = nil操作之后,这片内存空间b才会被释放。
同样地对于这样代码:
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 import UIKit class Person{ var name: String init(name: String){ self.name = name print("Person", name, "is initialized") } deinit{ print("Person", name, "is being deinitialized!") } } var person1: Person? = Person(name: "liuyubobobo") var person2: Person? = person1 var person3: Person? = person1那么person1的内存空间的引用计数为3,如果释放这片内存空间的话,需要将三个对象都为nil
如果仅仅是将person1=nil的话,并不会释放这一片内存空间。
以上这篇详谈swift内存管理中的引用计数就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/winterfells/archive/2017/09/04/7476485.html
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
python内存管理机制:引用计数垃圾回收内存池1.引用计数当一个python对象被引用时其引用计数增加1;当其不再被变量引用时引用计数减1;当对象引用计数等于
简单来说python的内存管理机制有三种1)引用计数2)垃圾回收3)内存池接下来我们来详细讲解这三种管理机制1,引用计数:引用计数是一种非常高效的内存管理手段,
内存管理中经常会遇到的一个问题便是循环引用。首先,我们来了解一下iOS是如何进行内存管理的。和OC一样,swift也是使用自动引用计数ARC(AutoRefer
Python引入了一个机制:引用计数。引用计数python内部使用引用计数,来保持追踪内存中的对象,Python内部记录了对象有多少个引用,即引用计数,当对象被
从三个方面来说,主要有方面的措施:对象的引用计数机制、垃圾回收机制、内存池机制。一、对象的引用计数机制Python内部使用引用计数,来保持追踪内存中的对象,所有