KVO Key Value Observing(基于键值的观察者)
每次指定的观察的对象的属性被修改后,KVO就会自动通知相应的观察者。
注册观察者:(给某对象添加观察者)
addObserver: forKeyPath: options: context:
下图是给children对象添加一个观察者,观察小孩的属性高兴值happyValue
//使用KVO为_children对象添加一个观察者,用于观察监听hapyValue属性值是否被修改了
[_children addObserver:self forKeyPath:@“hapyValue”
options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld
context:NULL];
//KVO触发的方法,hapyValue值如果被修改了,则调用此方法
-(void)observeValueForKeyPath:(NSString *)keyPath
ofObject:(id)object
//object 就是被观察的对象
change:(NSDictionary *)change
context:(void *)context{
if( [keyPath isEqualToString:@“happyValue”] ){
}
// NSNumber *hapyValue1 = [
change objectForKey:@“
new”]; //被监听的属性改变后的新值
// NSNumber *hapyValue2 = [
change objectForKey:@“
old”]; //被监听的属性改变前的旧值
// change里面有什么值取决于之前添加KVO时给option参数传什么值。
}
接受变更通知:
observeValueForKeyPath: ofObject: change: context: 所有观察者都必须实现这一方法。
使用KVO有三种方法:
1) 使用了 KVC
使用了 KVC ,如果有访问器方法,则运行时会在访问器方法中调用 will/didChangeValueForKey: 方法;
没用访问器方法,运行时会在 setValue:forKey 方法中调用 will/didChangeValueForKey: 方法。
2) 有访问器方法
运行时会重写访问器方法调用 will/didChangeValueForKey: 方法。
因此,直接调用访问器方法改变属性值时, KVO 也能监听到。
3) 显示调用 will/didChangeValueForKey: 方法。
1) 使用了 KVC
使用了 KVC ,如果有访问器方法,则运行时会在访问器方法中调用 will/didChangeValueForKey: 方法;
没用访问器方法,运行时会在 setValue:forKey 方法中调用 will/didChangeValueForKey: 方法。
2) 有访问器方法
运行时会重写访问器方法调用 will/didChangeValueForKey: 方法。
因此,直接调用访问器方法改变属性值时, KVO 也能监听到。
3) 显示调用 will/didChangeValueForKey: 方法。
观察者销毁时要将自己从被观察者身上移除
[_children removeObserver:self forKeyPath:@“hapyValue” ];
KVO与代理的区别:
代理只能一对一
KVO能一对多
补充:
设置定时器:
NSTimer *timer = [NSTimer scheduleTimeWithTimeInterval:1
target:self selector:@selector(timerAction:)
userInfo:@“参数” repeats:YES];
//方法名自定义的。
-(void)timerAction:(NSTimer *)timer{
NSString *s = timer.userInfo; //若传过来的是个数组,这里接收的就是数组。
[timer invalidate]; //用参数timer终止定时器
}
[timer invalidate]; //终止定时器
程序不停:[[NSRunLoop currentRunLoop] run];