Swift中如何管理内存?
来源:互联网 发布:spss19.0破解软件 编辑:程序博客网 时间:2024/05/16 07:34
本文和大家分享的主要是swift 中内存管理相关内容,一起来看看吧,希望对大家 学习swift有所帮助。
Swift 是自动管理内存的。这意味着,你不需要主动释放内存。
比如Foo 内包含的 Bar ,可以随同 Foo 一起被释放:
import UIKit@UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate {
var window : UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
Foo()
return true
}
} class Foo {
let bar: Bar
init() {
bar = Bar()
}
deinit {
print("Foo exit")
}
} class Bar {
deinit {
print("Bar exit")
}
}
执行此代码,会打印:
Foo exit
Bar exit
可见Foo 和 Bar 都是自动释放的。作为程序员,你不需要做任何内存的主动释放。
但是,有一种特殊情况,叫做双向引用,导致释放A 时,需要释放 B ,而 B 又引用了 A ,那么两个都无法被释放:
class Foo {
let bar: Bar
init() {
bar = Bar()
bar.foo = self
}
deinit {
print("Foo exit")
}
} class Bar {
var foo: Foo? = nil
deinit {
print("Bar exit")
}
}
此代码只会打印:
App exit
此时,需要做的就是把这个双向引用中的一个设置为weak ,表示的意思是尽管我持有这个引用,但是释放的时候,却无需考虑此对象的释放。
import UIKit@UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate {
var window : UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
Baz()
print("App exit")
return true
}
} typealias Bar = (()->Void) class Foo {
func work(_ bar : Bar) {
bar()
}
deinit {
print("Foo exit")
}
} class Baz {
var a : String?
init (){
a = "1"
let f = Foo()
f.work(){[ weak self]() in
print( self?.a)
}
}
}
当然,不标记也是不行的,因为编译器就不会通过,它要求只要引用了self ,就必须标记。
来源: 稀土掘金
阅读全文
0 0
- Swift中如何管理内存?
- Swift-内存管理
- swift 内存管理
- Swift中的内存管理
- Swift中的内存管理
- swift - 内存管理
- swift - 内存管理
- Swift OC 内存管理
- Swift--15内存管理
- Swift中的内存管理
- Swift内存管理-示例讲解
- [Swift内存管理-示例讲解]
- Swift内存管理(ARC)
- Swift内存管理-示例讲解
- Swift 基础学习(内存管理)
- Swift 中的内存管理详解
- 14.3 Swift内存管理模型
- 如何在MyEclipse中管理JVM内存?
- 判断checkbox是否选择并且弹出选择的值
- JVM调优总结(2):基本垃圾回收算法
- PCIe TPH analysis
- 矩阵奇异值分解(SVD)及其应用
- Myeclipse中 Hibernate的设置
- Swift中如何管理内存?
- [HDU-5978] [Problem H]概率,找规律,简单博弈,水题(16大连站)
- Linux环境下段错误的产生原因及调试方法小结
- Java 元编程及其应用
- Bootstrap
- hibernate绑定session
- Leetcode:Construct Binary Tree from Inorder and Postorder Traversal
- java小算法—统计句子中每个单词出现的次数
- 阶乘