闭包

截屏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
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 引言 继续学习Swift文档,从上一章节:函数,我们学习了Swift函数相关的内容,如函数的定义和使用、函数参数、...
    shiyueZ阅读 1,911评论 0 1
  • 一切皆对象 js中的一个常见运算符 typeof 以上代码列出了 typeof 输出的集中类型标识, 其中上面的四...
    无迹落花阅读 2,015评论 0 5
  • 在 Lua 语言中,函数是严格遵循词法定界的第一类值。“第一类值” 意味着 Lua 语言中的函数与其他常见类型的值...
    大宝777阅读 412评论 0 0
  • 利用了一个下午的时间,将原型和闭包这块的知识去了解了一下,做了些笔记和总结,感兴趣的童鞋可以移步王福朋的博客,写的...
    好奇的猫猫猫阅读 257评论 0 1
  • 介绍 Swift官方开发文档对于闭包的介绍是这样的:闭包是可以在代码中被传递和引用的功能性独立模块。Swift 中...
    Latte_Bear阅读 879评论 0 1