结构体值类型使用
测试结构体与类的内存分配
做一个简单测试实例,对比结构体 与 类,主要参考耗时
从测试结果来看,两组对比,类的内存开辟消耗时间均 比 结构体值类型内存开辟时间长
引用类型内存开辟与访问比值类型 内存访问多一个层级
或者 可以简单粗暴理解为 :
引用类型访问堆,在堆上开辟空间;值类型直接在栈上开辟空间,少一个层级寻址,耗时短
值类型应用
字典取值常规方式
根据前面的测试,引用类型的访问比值类型更耗时,内存开销更大
改用值类型
这样调整之后,在字典取值频繁,依赖度高的情况下,能节省掉不少内存空间与时间消耗
结构体内部方法不能修改成员变量
mutaing 关键字解决
通过swift 编译 中间语言 查看
参数多了个关键字 @inout
参考官方 sil 文档描述
inout 相当于参数拿到了对象指针 (也就是self指针)
没有inout 修饰的参数 就是接收 结构体的值
swift 方法中最后一个参数为默认参数 self, oc中有两个默认参数,self 和 cmd
加上打印
p2 是 通过p1 直接赋值,其实拷贝了一份内存
p3 是 拿到了 p1的指针
p1 通过 change方法 变更了 age, p2是独立内存,保持不变,p3指针指向的内存age 已经变更
异变方法的本质
对于变异的方法,方法默认参数(最后一个参数 self 被标记为 inout), 无论在 mutaing 修饰的方法内部发生什么,都会影响外部依赖类型的一切
swift func 形式参数是let 修饰的,也就是在func 内部内部不能修改 形参的值, 如果要修改 ,就需要 @inout 修饰参数