C++發(fā)布訂閱和觀察者模式的區(qū)別是什么

本篇內(nèi)容主要講解“C++發(fā)布訂閱和觀察者模式的區(qū)別是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“C++發(fā)布訂閱和觀察者模式的區(qū)別是什么”吧!

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比永和網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式永和網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋永和地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。

前段時(shí)間心血來(lái)潮自己寫一一個(gè)promise, promise剛好就是訂閱發(fā)布模式,工作中開發(fā)用的mobx 整體又是觀察者模式,雖然都用,但一直沒(méi)去細(xì)想兩者的差異,網(wǎng)上的區(qū)別分析看的云里霧里。結(jié)合一下 整理一篇自己的總結(jié)和最簡(jiǎn)單實(shí)現(xiàn)(也因?yàn)楹?jiǎn)單 所以也很好理解)做個(gè)分享同時(shí)加深自己對(duì)這兩者的理解

訂閱發(fā)布

1、實(shí)現(xiàn)思路

  • arr 做訂閱了的事件的緩存中心

  • 通過(guò)過(guò)on把需要做的事push arr 緩存數(shù)組中

  • 等待事件觸發(fā)時(shí) 依次emit執(zhí)行事件

2、代碼實(shí)現(xiàn)

interface eventHub {
  arr: Array<Function>;
  on(fn: Function): void;
  emit(): void;
}
interface Person {
  age: number;
  name: string;
}
let eventHub: eventHub = {
  arr: [] as Array<Function>,
  // 訂閱
  on(fn: Function) {
    this.arr.push(fn);
  },
  //   發(fā)布
  emit() {
    this.arr.forEach((fn) => fn());
  },
};
let person: Person = {} as Person;
eventHub.on(() => {
//訂閱的事件里判斷當(dāng) person長(zhǎng)度為2時(shí) 打印person,
  if (Object.keys(person).length == 2) {
    console.log(person);
  }
});
setTimeout(function () {
  person.age = 27;
  //發(fā)布的時(shí)候去遍歷 this.arr 并執(zhí)行第一次
  eventHub.emit();
}, 10);
setTimeout(function () {
  person.name = "Zoe";
  //發(fā)布的時(shí)候去遍歷 this.arr 并執(zhí)行第二次
  eventHub.emit();
}, 20);

3、結(jié)果

雖然發(fā)布了兩次 但最終on 里的console因?yàn)橥獠織l件只執(zhí)行了一次

C++發(fā)布訂閱和觀察者模式的區(qū)別是什么

觀察者模式

1、實(shí)現(xiàn)思路

與觀察者模式類似,但需要分一個(gè)觀察者,和被觀察者

  • 觀察者和被觀察者存在關(guān)聯(lián),(內(nèi)部基于發(fā)布訂閱模式)

2、代碼實(shí)現(xiàn)

// 被觀察者
class Subject {
  name: string; //實(shí)例上定義一個(gè)name屬性
  state: string;
  observers: any[];
  constructor(name:string) {
    this.name = name;
    this.observers = [];
    this.state = "";
  }
  attach(o) {
    //傳入觀察者
    this.observers.push(o);
  }
  setState(newState) {
    this.state = newState;
    this.observers.forEach((o) => o.update(this));
  }
}
// 觀察者
class Observer {
  name: string;
  constructor(name) {
    this.name = name;
  }
  update(interviewee) {
    console.log(`${interviewee.name} say to: ${this.name} ZOE的${interviewee.state}`);
  }
}
let hr = new Subject("HR");
let observer1 = new Observer("內(nèi)推者");
let observer2 = new Observer("面試者");
hr.attach(observer1);
hr.attach(observer2);
hr.setState("面試通過(guò)了");
// baby.setState("面試沒(méi)通過(guò)");

3、實(shí)現(xiàn)結(jié)果

C++發(fā)布訂閱和觀察者模式的區(qū)別是什么

兩者的區(qū)別

eventHub 發(fā)布訂閱

  • on(訂閱)和發(fā)布(emit)之間沒(méi)有直接聯(lián)系,是依賴中間的arr 做銜接 訂閱一個(gè)push 到arr一個(gè),emit的時(shí)候依次執(zhí)行arr

觀察者模式

  • 觀察者和被觀察者存在關(guān)聯(lián),(內(nèi)部基于發(fā)布訂閱模式)

  • 將觀察者的實(shí)例作參數(shù) 傳入被觀察者的attach方法中 并緩存在observers 數(shù)組中

  • 當(dāng)觀察者setState時(shí)候 依次調(diào)用緩存數(shù)組observers 中觀察者的update方法

到此,相信大家對(duì)“C++發(fā)布訂閱和觀察者模式的區(qū)別是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

本文標(biāo)題:C++發(fā)布訂閱和觀察者模式的區(qū)別是什么
標(biāo)題路徑:http://m.kartarina.com/article36/pgodsg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作微信公眾號(hào)外貿(mào)網(wǎng)站建設(shè)網(wǎng)站設(shè)計(jì)公司靜態(tài)網(wǎng)站定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
主站蜘蛛池模板: 久久av高潮av无码av喷吹| 人妻AV中出无码内射| 亚洲精品无码MV在线观看| 日韩美无码五月天| 在线高清无码A.| 国产成年无码久久久久下载| 日韩久久无码免费毛片软件| 久久久久亚洲精品无码系列| 一本大道无码人妻精品专区| 日韩午夜福利无码专区a| 色欲香天天综合网无码| 国产aⅴ无码专区亚洲av| 色视频综合无码一区二区三区| 亚洲综合一区无码精品| 亚洲成A人片在线观看无码不卡 | 国产精品无码久久av| 无码人妻精品一区二区三区在线| 精品久久久久久无码人妻| 中文字幕精品三区无码亚洲| 亚洲AV无码码潮喷在线观看| 一本色道无码道在线| 久久国产精品成人无码网站| 无码人妻丰满熟妇区五十路百度| 中文无码AV一区二区三区| 国产福利电影一区二区三区久久老子无码午夜伦不 | 中文字幕久久精品无码| 国模无码视频一区| 亚洲成在人线在线播放无码| 无码人妻久久一区二区三区| 亚洲国产成人精品无码区在线观看 | 中文字幕人成无码人妻| 麻豆aⅴ精品无码一区二区| 久久久久无码国产精品一区| 亚洲av无码无在线观看红杏| 国产午夜片无码区在线播放| 亚洲av无码无在线观看红杏| 色AV永久无码影院AV| 久久AV无码精品人妻糸列| 亚洲av午夜精品无码专区| 久久AV无码精品人妻糸列| 无码熟妇人妻av|