gpt4 book ai didi

详谈swift内存管理中的引用计数

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章详谈swift内存管理中的引用计数由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

在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 。

最后此篇关于详谈swift内存管理中的引用计数的文章就讲到这里了,如果你想了解更多关于详谈swift内存管理中的引用计数的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com