分类(Category)
用分类做什么?
- 声明私有方法,只把投文件放在宿主.m文件中,对外不堡垒
- 分解体积庞大的类
- Framework的私有方法公开化
用分类的特点(和扩展的区别)?
在运行时决议(扩展不是)
在运行时,通过Runtime给到宿主类可以为系统类添加分类(扩展不可以)
源码分析
用分类可以什么内容?
- 实例方法
- 类方法
- 协议
- 属性
没有添加了实例变量,只是声明了get和set方法
用关联对性才能生成实例变量
runtime680源代码在苹果官方网站上有,可以看到分类的结构体。
- 加载调用栈
https://blog.csdn.net/ochenmengo/article/details/104791008?spm=1001.2014.3001.5501
最后编译的分类的方法会覆盖掉之前的,倒序遍历的。
分类的同名方法会“覆盖“,原类方法仍然存在(返回了)
名字相同的分类会引起编译的报错
关联对象
怎么给分类添加”成员变量“?
不能再分类声明和实现时候添加成员变量,但是通过关联对象的技术来给分类实现达到给分类添加成员变量(鲜果上)关联对象是被添加到哪里了呢?
https://blog.csdn.net/ochenmengo/article/details/104813322?spm=1001.2014.3001.5501
扩展
扩展是做什么?
私有属性
声明私有方法
私有成员变量分类和扩展的区别是什么?
扩展是编译时决议
只有声明没有实现(寄生在在宿主的.m上)
不能给系统类添加扩展(分类可以)
代理
准确的说是一种软件设计模式
iOS当中用@Preoerty来实现
一对一(通知一对多)
协议可以定义什么?
方法和属性协议中声明的方法和属性代理方必须实现吗?
不一定 optional 和 required
- 一百声明为weak以规避循环引用
代理方是强引用委托方面的
通知(NS开头的,没有开放出来源码)
通知的的特点
是使用观察者模式实现的用于跨层传递消息的机制
一对多如何实现通知机制?
(加入让你设计,你会怎么实现通知的机制的?)
https://blog.csdn.net/ochenmengo/article/details/104902022?spm=1001.2014.3001.5501
KVO
- 什么是KVO?
- Key value observing
- 是Objective - C对观察者模式的又一个实现
- Apple 使用了isa混写(isa - swizzling)来实现KVO。
KVO的时间机制是什么的?
通过KVC设置的话是否能够生效?为什么能实现呢?
能,KVC出发了setter方法,setter方法已经被运行时动态创建的子类重写了。通过对成员变量直接赋值的话是没有办法被观察的。
可以在直接赋值的方法里面仿写做到,手动KVO
- 总结
使用Setter方法改变值会触发KVO
使用KVC方法设置值也会触发KVO
成员变量直接修改需要用手动添加KVO的方法
KVC
什么是KVC?
键值编码,Key-Value-codingKVC是否破坏了面向对象的编程思想?
是的,应为在外部可以修改
Accessor Method是否存在访问器
getKey
isKey
keyInstance var
_key
_isKey
isKey
key
属性关键字的分类
读写权限的
readOnly
readWrite(默认)原子性的
atcomic(默认的,可以保证赋值和获取是线程安全的,这里的赋值只队成员变量的获取和赋值,不是操作和访问。atomic数组添加和移除对象是没有atcomic负责不了的,既不安全)
nonatomic
- 引用计数的
retain(MRC)/strong(ARC)
assign(ARC) / unsafe_unretained(基本退出舞台了)
weak
copy
assign
修饰基本数据类型int BOOL等
修饰对象类型时候,不改变其引用计数
会产生悬垂指针的weak
不改变修饰对象的引用计数
所指向的对象呗适当之后会自动置为nilweak指针为什么被释放之后会成为nil呢?
*copy
*浅拷贝
对内存地址复制,没有开辟新内存,引用计数会+1
*深拷贝
开辟了新的内存空间,元内存的引用计数不会+1
*深浅拷贝
是否开辟了新的内存空间
引用计数是否会加1
- 总结
retain修饰的属性怎么重写setter方法
简述分类实现原理?
KVO的实现原理?
能否为分类添加成员变量?
https://blog.csdn.net/ochenmengo/article/details/104905085?spm=1001.2014.3001.5501