一、关于观察者模式,NSNotification/KVC/KVO机制:
http://www.cnblogs.com/pengyingh/articles/2383629.htmlhttp://www.cppblog.com/kesalin/archive/2012/11/17/kvo.html
KVC/KVO原理详解及编程指南: http://www.tuicool.com/articles/M7vQRj
这些文章介绍的很清楚了。
key-value observing,顾名思义,键值观察机制。key-value,对象的属性值。如果希望在A对象的x属性的值发生改变时,能够通知到B对象,使其作出相应的行为。那么就可以使用kvo机制,添加B对象为A对象的观察者。而B对象需要实现一个函数-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context,在里面实现收到通知后的行为。例如在主界面view展示一个不断变化的值。
KVO (Key Value Observing)是ios里面一种特别方便的机制用于“捕捉”对象属性的变化。在概念理解上,是设计模式里面观察者模式的一种实践。
1、KVC简介
2、KVO简介
拿一个具体的例子来讲:
有一个数据对象EmployeeData,该对象有一个属性salary
有一个ViewController 用于显示对象EmployeeData的属性salary的值
当salary的值发生变化的时候,ViewController如何显示变化后的新值。
方案一:
“可以在EmployeeData类弱引用ViewController类,然后在EmployeeData数据发生变化时,调
用ViewController类的回调函数。这个方法虽然能达到目的,但是会破坏EmployeeData的完整
性,一个负责数据管理的类,不应当依赖另一个负责视图控制的类;换句话说,EmployeeData
类不应该知道关于ViewController类的任何事情,甚至不需要知道其从在”
方案二:
使用ios提供的消息中心(NSNotificationCenter)。在此EmployeeData为消息生产者,ViewController为消息消费者。当salary数据发生变化时发送一个消息既可。
ViewController接收到salary数据变化的通知做相对应的业务处理。不足之处如同方案一,EmployeeData对象的salary每次变动都需要发送“通知”。这项工作对EmployeeData自身来讲毫无意义。
方案三:
在ViewController中将自身(self)设置为EmployeeData salary属性值变化的观察者。当salary值发生变化时,执行一个回调方法。这样对“EmployeeData”来讲不用关心除自身业务以
外的事情。避免了方案一和方案二的瑕疵。对ViewController来讲关注谁的变化,注册自己为其的观察者既可。间接轻便。
二、正式协议/非正式协议:
http://blog.csdn.net/ajrm0925/article/details/7419043
三、NSInteger和NSNumber:
http://blog.csdn.net/wzzvictory/article/details/8614433
四、ARC
http://blog.csdn.net/q199109106q/article/details/8565561
五、GCD
gcd 详解 http://blog.csdn.net/totogo2010/article/details/8016129
ios 6.0和mac os 10.8以上,GCD内存管理纳入ARC的管理范围,所以部署版本高于ios 6.0和mac os 10.8,则不需要dispatch_release()