本篇内容主要讲解“java的观察者模式的介绍及使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java的观察者模式的介绍及使用”吧!
一、定义
观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象(通知者)。这个主题对象观察到被观察者发生变化时,会通知所有的观察者对象,使它们能够自己更新自己
这里涉及了几个角色及他们自己功能:
- <李>
观察者对象:可以更新自己
李> <李>主题对象:可以添加观察者,移除观察者,通知观察者
李> <李>被观察者:被主题对象监视,当被观察者发生变化时,主题对象会通知观察者更新自己的状态
二、使用场景
当一个对象改变需要同时改变其他对象的时候,而且不需要知道有多少个对象需要改变
三,举个例子
如果干巴巴的概念描述晦涩难懂,举个生活中常见的例子说明一下
场景1:
写字楼中,电脑跟前。一堆程序员趁老板出差的机会在电脑上NBA球赛,时不时激动的大喊大叫。此时,老板出差回来,刚好碰个正着,场面一度尴尬。
解决方案:
为了避免在公司划水摸鱼时,被进门的老板抓到,几个人想了个方案,贿赂前台小姐姐。当老板以后再进公司门的时候,小姐姐立马通知程序员们,让他们恢复到工作的状态
场景2:
写字楼中,电脑跟前。一堆程序员趁老板出差的机会在电脑上NBA球赛,时不时激动的大喊大叫。此时,老板出差回来。前台小姐姐看到老板回来,立马给看球赛的小哥哥们发通知。此时小哥哥们赶紧切换成工作的状态。
场景2就是使用了观察者模式。当老板回来,时程序员们需要改变划水的状态,由前台小姐姐负责通知他们
人物角色功能程序员观察者可以改变自己的状态前台小姐姐主题(通知者)收集,移除及保存需要通知的程序员(观察者),给程序员发送通知老板被观察者被前台小姐姐观察通过案例应该分清观察者模式中的各个对象及各个对象的功能了。接下来进行编码
四、编码
1,前台小姐姐类(通知者类)
/* ,* desc:通知者类 ,* 1,存储观察者 ,* 2,添加观察者 ,* 3,移除观察者 ,* 4,通知观察者 ,*/class Dep  { ,,,构造函数(),{ ,,,,,,,//存储观察者 ,,,,,,,this.subs =, [] ,,,} ,,,/* * ,,,,*,添加观察者 ,,,,*,@param {观察者对象},sub ,,,*/,,,addSubs(子),{ ,,,,,,,//确保观察者都有更新方法 ,,,,,,,if (sub ,,, sub.update), { ,,,,,,,,,,,this.subs.push(子) ,,,,,,,} ,,,} ,,,/* * ,,,,*,移除观察者 ,,,,*,@param {需要移除的观察者对象},sub ,,,*/,,,removeSub(子),{ ,,,,,,,this.subs.forEach((项目,,指数),=祝辞,{ ,,,,,,,,,,,if (sub.id ===, item.id), { ,,,,,,,,,,,,,,,this.subs.splice(指数,1) ,,,,,,,,,,,,,,,返回; ,,,,,,,,,,,} ,,,,,,,}) ,,,} ,,,/* * ,,,,*,通知观察者,调用所有观察者内部的更新的方法,改变自身状态 ,,,*,*/,,,notify (), { ,,,,,,,this.subs.forEach (sub =祝辞,{ ,,,,,,,,,,,sub.update () ,,,,,,,}) ,,,} }
2,程序员类(观察者类)
/* * ,*观察者对象 ,*/class watcher  { ,,,构造函数(名字),{ ,,,,,,,this.name =,名字 ,,,} ,,,//观察者对象都有自己的更新方法,来改变自己的工作状态 ,,,更新(),{ ,,,,,,,console.log (“$ {this.name}收到通知,改变工作状态”。) ,,,} }/* * ,*观察者对象 ,*/class watcher  { ,,,构造函数(名字),{ ,,,,,,,this.name =,名字 ,,,} ,,,//观察者对象都有自己的更新方法,来改变自己的工作状态 ,,,更新(),{ ,,,,,,,console.log (“$ {this.name}收到通知,改变工作状态”。) ,,,} }
3模拟老板回公司,前台小姐姐通知程序员
, & lt; https://www.yisu.com/zixun/script src=" ./js/Dep.js "> 脚本>