Swift4 内存管理, 可选链, KeyPath
创建: 2018/03/09
完成: 2018/03/09
参照型数据与ARC | |
ARC |
● Swift里, 只有类实例与闭包实例是参照型 ● 生成时参照值为1, 被代入等每次+1, 减少每次-1 ● 为0运行deinit并自动释放 ● 判定实例是否相同 ===/!== ===运算符: 判定是否指向同一个内存位置(类实例, 闭包实例) !==: ===的否定 |
ARC内存管理 | 用ARC进行内存管理就是ARC内存管理 |
强参照循环 | |
实例无法释放的情况 |
参照循环, 即多个属性互相参照 解决方案就是下面两条: 弱参照, 非所有参照 |
弱参照 |
● 参照时被参照物的参照计数不会增加, 加 weak 必须是var, 因为被参照物被释放时值自动改为nil weak var sample: SampleClass 类实例必须至少有一个强参照, 不然ARC=0, 直接释放 ● 零化, 参照物被释放时值自动改为nil ● 用法: 类内部的类实例属性用weak, 防止循环参照 |
非所有参照(unowned reference) |
● 参照时被参照物的参照计数不会增加, 加 unowned ● 和weak一样, 但是不会零化 ● 用法: 参照量不会变nil得情况下用unowned代替weak 类似于T!和T? ● 速度不重要时, 都用weak |
Xcode去表示参照关系 |
运行项目后, [Debug Memory Graph]按钮 箭头: 被参照物 <-- 参照物 |
可选链 | |
可选链 |
a?.b?.c? // a, b, c都非nil, 返回a.b.c |
可选链呼出方法 |
前面有nil时方法不执行, 方法的参数是方法也不执行 a?.b?.c?.getSampleData(data: createData(with: )) // getSampleData(data:)和createData(with:)都不执行 |
可选链的型 |
可选类型T? a?.b?.c?.name // String? 不用可选链时为T的, 用可选链为T? |
不返回值的方法的情况 |
不返回值的方法 // 三个返回的型相同 ● 可选链下不返回值的方法的返回型 Void? 作为条件 if a?.b?.c?.method(...) != nil {... } |
对可选链代入 |
● 左侧可选链取值失败则不代入, 右侧式子不会执行 ● 左侧可选链取值成功则可以代入 ● 除了代入, 复合代入也一样 +=, -=, *=, /=, ... |
key path | |
key path |
可选链那样的参照回路 \型名.路径 // \和型名间可以有空格, 路径可以是可选链或其他属性路径 例 let keyPath1 = \OptionalChainTestClass.complexData?.data ● 路径内不能带有方法名 ● KeyPath的型 KeyPath<起点型, 获取的型> 例 struct Sample { |
用key path进行值的操作 |
● 获取值 实例[keyPath: KeyPath实例] 例 let keyPath1 = \OptionalChainTestClass.complexData?.data ● 代入 实例[keyPath: KeyPath实例] = 新值 |
Swift4 内存管理, 可选链, KeyPath的更多相关文章
- Swift中的可选链与内存管理(干货系列)
干货之前:补充一下可选链(optional chain) class A { var p: B? } class B { var p: C? } class C { func cm() -> S ...
- 24小时学通Linux内核之内存管理方式
昨天分析的进程的代码让自己还在头昏目眩,脑子中这几天都是关于Linux内核的,对于自己出现的一些问题我会继续改正,希望和大家好好分享,共同进步.今天将会讲诉Linux如何追踪和管理用户空间进程的可用内 ...
- 十天学Linux内核之第三天---内存管理方式
原文:十天学Linux内核之第三天---内存管理方式 昨天分析的进程的代码让自己还在头昏目眩,脑子中这几天都是关于Linux内核的,对于自己出现的一些问题我会继续改正,希望和大家好好分享,共同进步.今 ...
- 启动期间的内存管理之bootmem_init初始化内存管理–Linux内存管理(十二)
1. 启动过程中的内存初始化 首先我们来看看start_kernel是如何初始化系统的, start_kerne定义在init/main.c?v=4.7, line 479 其代码很复杂, 我们只截取 ...
- 启动期间的内存管理之初始化过程概述----Linux内存管理(九)
在内存管理的上下文中, 初始化(initialization)可以有多种含义. 在许多CPU上, 必须显式设置适用于Linux内核的内存模型. 例如在x86_32上需要切换到保护模式, 然后内核才能检 ...
- [深入理解Java虚拟机]<自动内存管理>
Overview 走近Java:介绍Java发展史 第二部分:自动内存管理机制 程序员把内存控制的权利交给了Java虚拟机,从而可以在编码时享受自动内存管理.但另一方面一旦出现内存泄漏和溢出等问题,就 ...
- 内存管理(1)-buddy和slub算法
Linux内存管理是一个很复杂的系统,也是linux的精髓之一,网络上讲解这方面的文档也很多,我把这段时间学习内存管理方面的知识记录在这里,涉及的代码太多,也没有太多仔细的去看代码,深入解算法,这篇文 ...
- 【原创】xenomai内核解析--实时内存管理--xnheap
目录 一. xenomai内存池管理 1.xnheap 2. xnpagemap 3. xnbucket 4. xnheap初始化 5. 内存块分配 5.1 小内存分配流程(<= 2*PAGE_ ...
- linux内存管理
一.Linux 进程在内存中的数据结构 一个可执行程序在存储(没有调入内存)时分为代码段,数据段,未初始化数据段三部分: 1) 代码段:存放CPU执行的机器指令.通常代码区是共享的,即其它执行程 ...
随机推荐
- 1597: [Usaco2008 Mar]土地购买 [ dp+斜率优化 ] 未完
传送门 1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1979 Solved: 705[Subm ...
- windows 下安装Apache httpd 只需三步
1.下载 Apache 官网地址:http://httpd.apache.org/docs/current/platform/windows.html#down 找到这个, 看到这几个选项: Apac ...
- 理解 mysql行锁和表锁
在调用存储过程中,就会涉及到表锁,行锁这一概念:所谓区别:有索引的时候就是行锁,没有索引的时候就是表索. innodb 的行锁是在有索引的情况下,没有索引的表是锁定全表的. 表锁演示(无索引) Ses ...
- 洛谷—— P2802 回家
P2802 回家 题目描述 小H在一个划分成了n*m个方格的长方形封锁线上. 每次他能向上下左右四个方向移动一格(当然小H不可以静止不动), 但不能离开封锁线,否则就被打死了. 刚开始时他有满血6点, ...
- P2835 刻录光盘
洛谷—— P2835 刻录光盘 题目描述 在JSOI2005夏令营快要结束的时候,很多营员提出来要把整个夏令营期间的资料刻录成一张光盘给大家,以便大家回去后继续学习.组委会觉得这个主意不错!可是组委会 ...
- Permutations(排列问题,DFS回溯)
Given a collection of numbers, return all possible permutations. For example,[1,2,3] have the follow ...
- FTRL (Follow-the-regularized-Leader)算法
Online gradient descent(OGD) produces excellent prediction accuracy with a minimum of computing reso ...
- 【APUE】文件I/O
Linux的内核将所有外部设备都可以看做一个文件来操作.那么我们对与外部设备的操作都可以看做对文件进行操作.我们对一个文件的读写,都通过调用内核提供的系统调用:内核给我们返回一个file descri ...
- 【APUE】进程间通信之共享存储(mmap函数)
共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式,因为进程可以直接读写内存,而不需要任何数据的拷贝.对于像管道和消息队列等通信方式,则需要在内核和用户空间进行四次的数据拷贝,而共享内存则只 ...
- 【Mongodb教程 第七课 】MongoDB 查询文档
find() 方法 要从MongoDB 查询集合数据,需要使用MongoDB 的 find() 方法. 语法 基本的find()方法语法如下 >db.COLLECTION_NAME.find() ...