代理:
代理是 iOS 很常用的方式,它的特点就是一对一的形式,并且它的逻辑结构非常的清晰。实现起来也是比较简单的:
1.声明协议,通常是声明协议的类名+delegate;
2.定义一个代理属性;
3.设置代理
一般要注意以下几个方面:
- 协议定义时,请用关键字@required,和@optional来明确代理是否必须实现某些方法
- ** 代理的类型需要用 id 类型,还要写明要遵守的协议,同时为防止循环引用的产生,要用 copy 来修饰**
- ** 在调用代理方法的时候,一定要判断代理是否实现了该方法,以免发生没有实现该方法而导致程序崩溃**
- ** 在实现代理方法的时候一定要遵守相应的代理协议**
适用场景:
1.公共接口,回调方法较多也选择用delegate进行解耦
iOS最常用tableViewDelegate,textViewDelegate
2.两个界面之间的相互传值,这两个界面之间没有多么复杂的关系,然后需要自己定义代理,设置代理属性,声明代理方法,代理方遵守协议,判断并执行代理方法即可
通知:
通知相比于代理来说,更加的简单,首先他是一对多的形式,并且可以在任意对象之间传递,通知其实就是在通知中心注册通知,发通知,收通知。但是使用通知的时候一定要注意以下几点:
** 1.对于系统没有定义的事件监听时需要自己发通知,这是你就需要定义一个key,是字符串类型,这也是通知的一个弊端,你需要拷贝到收通知的对象,避免写错一个字母而无法收通知的尴尬,可以定义成宏.**
** 2.使用完通知之后,一定要记得移除掉通知,如果不移除通知,不仅会影响性能,还会造成意想不到的结果。**
使用场景:
1.当多个控制器都需要知道一个事件时,应该使用通知,比如一个事件会影响多个方法
2.想个多层的控制器之间的跳转和传值都需要使用通知
3.通知还可以用来监听键盘、前后台等系统使用情况。
block:
block 是 C语言的,类似于 C 函数,带有局部变量的匿名函数,类似 C 语言中的函数指针,可以当做参数传来传去,而且可以没有名字。
- 它是一种数据类型,可以当参数传递
- 说的简单点 block 就是一组预先准备好的代码,在需要的时候执行,无论在哪调用,block 执行都会回到 block 创建的地方执行
使用场景:
异步和简单的回调
block 最典型的就是总所周知的 AFNetworking 第三方库
注意点:
1.当 block 作为属性的时候要用 copy 修饰
因为防止在MRC下,如果block访问了外部变量,那么block就会存在栈区,当Block所在的作用域结束时就会被销毁,所以当在别的地方回掉时可能就会出错,为了避免这种情况就需要手动调用Block的copy方法copy到堆区,这也是Block当属性时用copy的原因.在MRC下需要手动管理内存(需要程序猿手动copy到堆区)
2.__weak
Block还有一个注意点就是,Block会对外部使用的变量和控制器进行强引用,为避免循环引用造成资源释放不了,需要用weak修饰外部变量和控制器
3.__block
block内部默认是不能修改外部变量的值,如果要修改使用__block修饰,一旦用__block修饰了,变量的地址就变成了堆区的地址
KVO:
KVO就是“键值观察”,观察者模式,它是用来监听对象的属性值的变化,当指定的被观察的对象的属性被修改之后,KVO 就会通过回调方法自动通知响应的观察者了,KVO 使用和通知极其的相似,两者都是一对多,使用步骤:
- 注册观察者,指定被观察者的属性
- 实现回调的方法
- 移除观察
KVO 在 Apple 中的 API 文档如下:
Automatic key-value observing is implemented using a technique called isa-swizzling… When an observer is registered for an attribute of an object the isa pointer of the observed object is modified, pointing to an intermediate class rather than at the true class …
KVO 底层实现原理其实就是 runtime 机制
基本的原理:
当观察者对象 A ,KVO 机制动态的创建一个对象 A 当前的子类,并为这个新的子类重写了被观察者的属性 keyPath 的 setter 方法。随后 setter 方法就负责通知观察对象属性的改变状况。
什么是 isa?
每个对象都有 isa 指针,指向该对象的类,它告诉 Runtime 系统这个对象的类是什么。所以当对象注册为观察者时,isa 指针指向新子类,那么这个被观察的对象就神奇的变成了新子类的对象。