本篇內(nèi)容主要講解“C++怎么發(fā)布訂閱和觀察者模式”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“C++怎么發(fā)布訂閱和觀察者模式”吧!
做網(wǎng)站、網(wǎng)站建設(shè)的開發(fā),更需要了解用戶,從用戶角度來建設(shè)網(wǎng)站,獲得較好的用戶體驗(yàn)。創(chuàng)新互聯(lián)建站多年互聯(lián)網(wǎng)經(jīng)驗(yàn),見的多,溝通容易、能幫助客戶提出的運(yùn)營建議。作為成都一家網(wǎng)絡(luò)公司,打造的就是網(wǎng)站建設(shè)產(chǎn)品直銷的概念。選擇創(chuàng)新互聯(lián)建站,不只是建站,我們把建站作為產(chǎn)品,不斷的更新、完善,讓每位來訪用戶感受到浩方產(chǎn)品的價(jià)值服務(wù)。
1、實(shí)現(xiàn)思路
arr 做訂閱了的事件的緩存中心
通過過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長度為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í)行了一次
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("面試通過了"); // baby.setState("面試沒通過");
3、實(shí)現(xiàn)結(jié)果
on(訂閱)和發(fā)布(emit)之間沒有直接聯(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方法
到此,相信大家對“C++怎么發(fā)布訂閱和觀察者模式”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
網(wǎng)頁題目:C++怎么發(fā)布訂閱和觀察者模式
文章來源:http://www.rwnh.cn/article30/jdcppo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、網(wǎng)頁設(shè)計(jì)公司、虛擬主機(jī)、服務(wù)器托管、移動(dòng)網(wǎng)站建設(shè)、全網(wǎng)營銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)