闭包

截屏2020-06-16 下午6.41.39.png

通过代码说明上述图片的问题:

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
截屏2020-06-11 下午7.06.35.png

截屏2020-06-11 下午7.11.53.png

截屏2020-06-11 下午7.17.27.png

你可能感兴趣的:(闭包)