闭包

作者: 沫粢泪虞 | 来源:发表于2020-12-01 15:28 被阅读0次
    截屏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

    相关文章

      网友评论

          本文标题:闭包

          本文链接:https://www.haomeiwen.com/subject/twhitktx.html