当你不爱我的时候,请告诉我(KVC/KVO/NSNotification)

KVC KVO NSNotification


一、KVC

====基本概念

它是一种可以直接通过字符串类型的属性名(key)来访问某个类属性的机制。而不是通过调用Setter、Getter方法访问。

所有NSObject对象都可以使用KVC。

KVC既支持带有对象值的属性,也支持基本数据类型和结构。基本数据类型会被自动封装和解装。

====基本使用

1.通过 setValue: forKey: 设置对象的值。

2.通过 valueForKey: 获得对象的值。

3.通过 setValue: forKeyPath: 设置指定路径的对象值。

4.通过 valueForKeyPath: 获得指定路径的对象值。

示例代码如下:

当你不爱我的时候,请告诉我(KVC/KVO/NSNotification)_第1张图片
当你不爱我的时候,请告诉我(KVC/KVO/NSNotification)_第2张图片

打印输出:

当你不爱我的时候,请告诉我(KVC/KVO/NSNotification)_第3张图片

====一对多关系

如果向NSArray等集合类型数据所包含的对象发送请求消息,它会查询数组中每个对象来查找这个键值,并返回一个打包后的数组。

如果想要向数组等集合类型的数据所包含的对象发送赋值消息,它也会查询数组中每个对象来查找这个键值,并赋同一个值。注意:不要企图发送一个数组让她为找到的对象按顺序赋值,这样会报错!

示例代码如下:

当你不爱我的时候,请告诉我(KVC/KVO/NSNotification)_第4张图片

打印输出

当你不爱我的时候,请告诉我(KVC/KVO/NSNotification)_第5张图片

二、KVO

====基本概念

KVO: Key-Value Observing,它提供一种机制,当指定的对象的属性被修改后,则对象就会接受到通知。就是每次指定的被观察的对象的属性被修改后,KVO就会自动通知相应的观察者。属于一种非正式的 Protocol。

可以观察任意属性,包括基本数据类型,对一或对多关系。对多关系的观察者将会被告知发生变化的类型,也即使任意发生变化的对象。

====使用方法

注册观察者,指定被观察者的属性。

实现回调方法,接收变更通知。

移除观察者身份。

====注册观察者

为了正确接收属性的变更通知,观察者必须首先发送一个 addObserver:forKeyPath:options:context: 消息给被观察者。用以传送需要观察的对象和需要观察的属性的关键路径,选型参数指定了发生变更时提供给观察者的信息,使用 NSKeyValueObservingOptionNew 可以在回调方法中获得旧值,使用 NSKeyValueObservingOptionOld 可以在回调方法中获得新值。

====示例

[person addObserver:self forKeyPath:@"books.price" options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld context:NULL];

====回调方法

当监听属性发生变化时,坚挺着将会收到一条 observeValueForKeyPath: ofObject: change: context: 消息。触发观察的对象、键路径、包含变化细节的字典都会传给观察者。

-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context {

if([keyPath isEqualToString:@"books.price"]) {

NSLog("通知我啦!");

}

}

====移除观察者

你可以发送一条包含观察者,键路径的方法 `` 给被观察的对象,来移除这个观察。

注意:注册了观察者就需要手动移除观察者!

[person removeObserver:self forKeyPath:@"books.price"];

三、NSNotification

====概述

与KVO不同的是,KVO在属性上通过 K-V 发生改变时,自动调用 observeValueForKeyPath: ofObject: change: context: 方法,而 NSNotification 在需要的时候自行发送通知才调用,且方法自定义。

====使用方法

NSNotificationCenter 注册观察者时指定事件(以字符串命名),及该事件触发时该执行的 Selector 或 Block

NSNotificationCenter 在某个时机激发事件(以字符串命名)

注意:编译器根据这个事件的名字找到之前注册过这个名字的观察者,所以这个名字一般设置成静态属性,保证两次使用是同一个字符串!

观察者在收到感兴趣的事件时,执行相应的 Selector 或 Block

====注册观察者

使用默认的通知中心,指定观察者、需要接收的通知名称、接收通知时执行的方法,最后一个参数是表示会对哪个发送者对象发出的事件作出响应,nil 时表示接受所有发送者的事件。

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(action:) name:@"NOTIFICATION_NAME" object:nil];

====激发观察者

需要指定通知的名称,编译器根据这个事件的名字找到之前注册过这个名字的观察者,还可以指定传给观察者的对象。

NSObject *test = [[NSObject alloc] init];

[[NSNotificationCenter defaultCenter] postNotificationName:@"NOTIFICATION_NAME" object:test];

//或者以下的方式:

NSNotification *notification = [NSNotification    notificationWithName:@"NOTIFICATION_NAME" object:test];

[[NSNotificationCenter defaultCenter] postNotification:notification];

====执行事件

观察者接受到通知后就会执行注册时指定的方法,并获得被观察者传回的对象。

- (void)action:(NSNotification *)notification {

NSLog("通知我啦!");

}

你可能感兴趣的:(当你不爱我的时候,请告诉我(KVC/KVO/NSNotification))