iOS 观察者模式—KVO

什么是观察者模式?

观察者模式.png

观察者模式是定义对象间的一种一对多的依赖关系,并且当一个对象的状态发生改变的时候,所有依赖于它的对象都会得到通知且自动更新。

iOS中实现观察者模式有两种方式:通知和KVO

  • 先了解KVO

我所理解的是KVO,一个是观察者,一个是被观察者,当然自己观察自己也是可以的,就像自我反省一样。观察者对被观察者的某个属性感兴趣,就把注意力放在这个属性上,当这个属性发生变化时,观察者就根据这个属性变化作出相对应的措施。至于什么措施,就因人而异啦😂!

  • 用一下吧
//用于观察的属性
@property (nonatomic, assign)  NSInteger  weekNum;//星期几

//赋初始值
 self.weekNum = 1;

//给自己添加观察者,观察自己的weekNum属性
 [self addObserver:self forKeyPath:@"weekNum" options:NSKeyValueObservingOptionNew context:nil];

NSKeyValueObservingOptionNew 通知中发送的更改字典包含新值
NSKeyValueObservingOptionOld 旧值
_weekNum 与 self.weekNum的区别
使用self.XXX 会调用set和get方法,而_XXX则直接访问实例变量并赋值,不会调用set和get方法
KVO观察属性!其实是观察set方法!!

  • 改变值
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
     self.weekNum++;
}
  • 属性变化调用
#pragma -mark ——————————监听值变化-——————————
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSKeyValueChangeKey,id> *)change context:(void *)context
{
    if ([keyPath isEqualToString:@"weekNum"]) {
        NSLog(@"%@",[object valueForKey:@"weekNum"]);
        NSLog(@"--change:--%@", [change objectForKey:@"new"]);
     //做对应的操作
    }
}
  • 最后别忘了移除
- (void)dealloc
{
    //移除观察者
    [self removeObserver:self forKeyPath:@"weekNum"];
}

添加观察者前后类的变化

打印isa指针指向的类

NSLog(@"isa-> %@", object_getClass(self));

添加前 :isa-> YHObserverPracticeVC
添加后:isa-> NSKVONotifying_YHObserverPracticeVC
移除后:isa-> YHObserverPracticeVC

  • 由此可见,观察的时候,动态的生成一个前缀为NSKVONotifying_+类名的子类,观察的是这个新生成类的set方法
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 13,794评论 1 32
  • 上一篇:iOS-KVC浅谈 前言:KVO 作为 KVC 的同袍兄弟,功能更强大,聊聊 KVO。 一、KVO 简介 ...
    梦蕊dream阅读 4,042评论 0 0
  • 问题 iOS用什么方式实现对一个对象的KVO?(KVO的本质是什么?) 如何手动触发KVO ? 首先需要了解KVO...
    hjltony阅读 3,619评论 0 2
  • KVC KVC定义 KVC(Key-value coding)键值编码,就是指iOS的开发中,可以允许开发者通过K...
    暮年古稀ZC阅读 6,490评论 2 9
  • 上半年有段时间做了一个项目,项目中聊天界面用到了音频播放,涉及到进度条,当时做android时候处理的不太好,由于...
    DaZenD阅读 8,105评论 0 26