
通过代码说明上述图片的问题:
import Foundation
typealias Fn = (Int) -> Int
func getFn() -> Fn { //代码段
var num = 0 //局部变量
print(Mems.ptr(ofVal: &num)) //堆区: 0x0000000100506ca0
func plus(_ i: Int) -> Int {
//实例对象内存结构默认为(isa指针地址,引用计数地址,其他局部变量组成)开辟的空间为16的倍数
//捕获外部局部变量时,会生成一块堆空间存储外部变量(此时内存结构与实例对象内存结构相似), 内部不进行捕获的时候它在栈空间,如果是全局变量,是不会重新生成堆空间的
num = num + i
print(Mems.ptr(ofVal: &num)) //堆区: 0x0000000100506ca0
return 0
}
return plus
}
var fn1 = getFn() //初始化闭包对象
fn1(2)
print("fn1变量的内存地址:\(Mems.ptr(ofVal: &p))") // 全局区(静态区 0x0000000100009470
print("fn1变量指向的内存地址:\(Mems.ptr(ofRef: p))") // 堆 0x0000000102919e30
class B {}
class A {
var num = 0
func test() {
print(Mems.ptr(ofVal: &num)) //堆 0x0000000102287ab0
var p = B()
print("p变量的内存地址:\(Mems.ptr(ofVal: &p))") //栈 0x00007ffeefbff308
print("p变量指向的内存地址:\(Mems.ptr(ofRef: p))") //堆 0x000000010392c110
}
}
var p = A()
p.test()
print("p变量的内存地址:\(Mems.ptr(ofVal: &p))") //全局区(静态区) 0x0000000100009470
print("p变量指向的内存地址:\(Mems.ptr(ofRef: p))") //堆 0x0000000102919e30



网友评论