Swift使用自动引用计数(ARC)来管理应用程序的内存使用。在大多是情况下,并不需要考虑内存的管理。当实例不再需要的时候,ARC会自动释放这些实例所使用的内存。
但ARC并不是绝对安全的。下面两种情况会发生内存泄露。
@H_301_2@
@H_301_2@
@H_301_2@
1,类实例之间的循环强引用
@H_301_2@
两个类实例都有一个强引用指向对方,这样的情况就是强引用循环,从而导致内存泄露。
@H_301_2@
@H_301_2@
@H_301_2@
解决办法:使用弱引用
class
Teacher
{
@H_301_2@
@H_404_111@
var
tName :
String
@H_301_2@
student :
Student
?
@H_301_2@
@H_301_2@
init
(name:
String
){
@H_301_2@
tName = name
@H_301_2@
println
(
"老师\(tName)实例初始化完成"
)
@H_301_2@
}
@H_301_2@
@H_301_2@
deinit{
@H_301_2@
"老师\(tName)实例反初始化完成"
)
@H_301_2@
}
@H_301_2@
}
@H_301_2@
@H_301_2@
{
@H_301_2@
sName :
String
@H_301_2@
|
解决办法:使用弱引用
只需要将上述例子Teacher类的student变量加上关键字weak,或者将Student类的teacher变量加上关键字weak。
当A类中包含有B类的弱引用的实例,同时,B类中存在A的强引用实例时,如果A释放,也不会影响B的释放。但A的内存回收要等到B的实例释放后才可以回收。
@H_301_2@
@H_301_2@
2
@H_301_2@
@H_301_2@
@H_301_2@
2,闭包引起的循环强引用
String @H_301_2@ |
2,闭包引起的循环强引用
将一个闭包赋值给类实例的某个属性,并且这个闭包体中又使用了实例,也会发生强引用循环。
@H_301_2@
31
@H_301_2@
@H_301_2@
@H_301_2@
解决办法:使用闭包捕获列表
JsonElement
let
name:
String
@H_301_2@
|
解决办法:使用闭包捕获列表
当闭包和实例之间总是引用对方并且同时释放时,定义闭包捕获列表为无主引用。但捕获引用可能为nil时,定义捕获列表为弱引用。弱引用通常是可选类型,并且在实例释放后被设置为nil。
@H_301_2@
23
@H_301_2@
@H_301_2@
@H_301_2@
@H_301_2@
原文出自: www.hangge.com 转载请保留原文链接: http://www.hangge.com/blog/cache/detail_742.html
name:
jValue:
asJson:() ->
[
unowned
]
in
//使用无主引用来解决强引用循环
@H_301_2@
|
原文出自: www.hangge.com 转载请保留原文链接: http://www.hangge.com/blog/cache/detail_742.html