0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于觀察者模式設(shè)計(jì)的框架-REB,使代碼模塊化

Rice嵌入式開(kāi)發(fā)技術(shù)分享 ? 來(lái)源:Rice 嵌入式開(kāi)發(fā)技術(shù)分享 ? 作者:Rice 嵌入式開(kāi)發(fā)技 ? 2023-10-17 09:35 ? 次閱讀

設(shè)計(jì)模式里面的觀察者模式,一直是作者想去設(shè)計(jì)一套框架來(lái)闡述這一個(gè)模式,因此REB(Rice Event Broker)就是為了完成觀察者模式的一個(gè)框架。

觀察者模式

聊REB之前,我們聊聊觀察者模式帶給我們特性,他能對(duì)我們框架設(shè)計(jì)提供什么好處。

什么是觀察者模式

觀察者模式(Observer Pattern)是一種行為設(shè)計(jì)模式,用于定義對(duì)象之間的一對(duì)多依賴關(guān)系,使得一個(gè)對(duì)象的狀態(tài)變化會(huì)通知其所有依賴者并自動(dòng)更新它們的狀態(tài)。這個(gè)模式涉及兩種主要類型的對(duì)象:

被觀察者:也稱為主題或可觀察者,是一個(gè)對(duì)象,它維護(hù)一組觀察者(或依賴者)并提供方法來(lái)添加、刪除和通知這些觀察者。當(dāng)被觀察者的狀態(tài)發(fā)生變化時(shí),它會(huì)通知所有已注冊(cè)的觀察者。

觀察者:觀察者是依賴于被觀察者的對(duì)象,它們實(shí)現(xiàn)一個(gè)接口或抽象類,包含一個(gè)更新方法(通常稱為update),用于接收并處理被觀察者的狀態(tài)變化通知。

觀察者模式工作流程

被觀察者注冊(cè)觀察者:被觀察者維護(hù)一個(gè)觀察者列表,并提供注冊(cè)(添加)和注銷(刪除)觀察者的方法。

被觀察者狀態(tài)變化:當(dāng)被觀察者的狀態(tài)發(fā)生變化,它會(huì)遍歷其觀察者列表,調(diào)用每個(gè)觀察者的更新方法,將狀態(tài)變化通知給它們。

觀察者響應(yīng):每個(gè)觀察者在接收到通知后會(huì)執(zhí)行自己的更新邏輯,以響應(yīng)被觀察者的狀態(tài)變化。

觀察者模式優(yōu)勢(shì)

「解耦性:」觀察者模式可以幫助降低對(duì)象之間的耦合度。被觀察者和觀察者之間的關(guān)系是松散的,它們可以獨(dú)立演化,而不會(huì)影響彼此的具體實(shí)現(xiàn)。

「可擴(kuò)展性:」你可以輕松地添加新的觀察者,而不需要修改被觀察者的代碼。這種擴(kuò)展性使你能夠動(dòng)態(tài)地增加或刪除觀察者,以滿足不同的需求。

「通知機(jī)制:」觀察者模式允許被觀察者通知觀察者,從而使觀察者能夠在適當(dāng)?shù)臅r(shí)候進(jìn)行響應(yīng)。這可以幫助確保數(shù)據(jù)的一致性,因?yàn)橛^察者會(huì)立即知道被觀察者的狀態(tài)變化。

「分布式事件處理:」觀察者模式常用于實(shí)現(xiàn)分布式事件處理系統(tǒng),其中多個(gè)觀察者可以遠(yuǎn)程訂閱和接收事件通知。

「可重用性:」觀察者模式可以在不同的應(yīng)用中重復(fù)使用,因?yàn)樗且粋€(gè)通用的設(shè)計(jì)模式,不受特定應(yīng)用領(lǐng)域的限制。

「靈活性:」觀察者模式可以用于許多不同的場(chǎng)景,如用戶界面更新、事件處理、數(shù)據(jù)同步等,使得代碼更加靈活和可維護(hù)。

「支持一對(duì)多關(guān)系:」觀察者模式支持一對(duì)多的依賴關(guān)系,這意味著一個(gè)被觀察者可以同時(shí)通知多個(gè)觀察者,從而實(shí)現(xiàn)多個(gè)對(duì)象之間的協(xié)同工作。

觀察者模式例子

物聯(lián)網(wǎng)協(xié)議MQTT:MQTT(Message Queuing Telemetry Transport,消息隊(duì)列遙測(cè)傳輸協(xié)議),是一種基于發(fā)布/訂閱(publish/subscribe)模式的“輕量級(jí)”通訊協(xié)議。

Android的EventBus:EventBus是一個(gè)基于發(fā)布者/訂閱者模式的事件總線框架。

REB框架設(shè)計(jì)

REB框架圖

9c0afb10-6c0f-11ee-b3e3-92fbcf53809c.png

REB框架說(shuō)明

REB框架分為3層:osal(OS抽象層),REB核心層(包含發(fā)布者,觀察者,中間人),應(yīng)用層(調(diào)用REB的模塊或應(yīng)用)。

osal(OS抽象層):為了能讓此框架應(yīng)用于不同的操作系統(tǒng),且不用修改框架本身,所以提供os適配層。

REB核心層(包含發(fā)布者,觀察者,中間人):框架的三大角色,它們?nèi)呋ハ嘁蕾嚒?/p>

publisher(發(fā)布者):REB框架的發(fā)布者支持4種接口:默認(rèn)發(fā)送接口,默認(rèn)發(fā)送完釋放數(shù)據(jù)內(nèi)存釋放接口,緊急發(fā)送接口,緊急發(fā)送完數(shù)據(jù)內(nèi)存釋放接口。

observer(觀察者):REB框架的觀察者支持3種接口:信號(hào)接收接口,回調(diào)接收接口,線程接收接口。

broker(中間人):REB框架的中間人支持兩種接口:觀察者只觀察一次接口,觀察者觀察多次接口。

應(yīng)用層(調(diào)用REB的模塊或應(yīng)用):上層應(yīng)用或者模塊,相互獨(dú)立,互不依賴。

REB是以事件為導(dǎo)向,事件類型由主事件類型和次事件類型組成,事件類型占用32個(gè)位,主事件類型占高16位,次事件類型占低16位。一般:以網(wǎng)絡(luò)為例:主事件類型為:net_type,次事件類型為:link_up,link_down等。

REB目錄結(jié)構(gòu)

├─adapter
│├─cmsis
│|├─reb_mutex.c//cmsismutex適配層
│|├─reb_queue.c//cmsisqueue適配層
│|├─reb_sem.c//cmsissem適配層
│|└─reb_task.c//cmsistask適配層
│└─rtthread
│├─reb_mutex.c//rtthreadmutex適配層
│├─reb_queue.c//rtthreadqueue適配層
│├─reb_sem.c//rtthreadsem適配層
│└─reb_task.c//rtthreadtask適配層
├─example
│└─reb_rtt_example.c//rtthread平臺(tái)實(shí)例
├─include
│├─reb_broker.h//reb中間人的頭文件
│├─reb_cfg.h//reb參數(shù)配置文件
│├─reb_def.h//reb框架通用接口定義
│├─reb_observer.h//reb觀察者的頭文件
│└─reb_publisher.h//reb發(fā)布者的頭文件
└─src
├─reb_broker.c//reb中間人的源文件
├─reb_publisher.c//reb觀察者的源文件
└─reb_observer.c//reb發(fā)布者的源文件

REB接口說(shuō)明

broker接口

接口 說(shuō)明
broker_create 創(chuàng)建broker
broker_delete 刪除broker
broker_observer_attach_once 關(guān)聯(lián)觀察者到broker中,并只觀察一次
broker_observer_attach 關(guān)聯(lián)觀察者到broker中,并只觀察多次
broker_observer_detach 從broker中脫離觀察者

創(chuàng)建broker

在使用該框架時(shí),必須要通過(guò)此接口創(chuàng)建broker,它是發(fā)布者和觀察者的中間人。

reb_statusbroker_create(void);

「參數(shù)」 「描述」
-- --
「返回」 ——
REB_OK broker創(chuàng)建成功
REB_ERROR broker創(chuàng)建失敗

刪除broker

當(dāng)不再使用該框架時(shí),可以調(diào)用此接口刪除broker。

reb_statusbroker_delete(void);

「參數(shù)」 「描述」
-- --
「返回」 ——
REB_OK broker刪除成功
REB_ERROR broker刪除失敗

關(guān)聯(lián)觀察者到broker中,并只觀察一次

我創(chuàng)建的觀察者之后,需要通過(guò)此接口將觀察者關(guān)聯(lián)到broker中。當(dāng)發(fā)布者發(fā)布事件,可以通過(guò)broker找到對(duì)用的觀察者。使用該接口觀察者只觀察一次事件。

reb_statusbroker_observer_attach_once(observer_base*obs);

「參數(shù)」 「描述」
obs 觀察者對(duì)象
「返回」 ——
REB_OK 關(guān)聯(lián)觀察者到broker中,成功
REB_ERROR 關(guān)聯(lián)觀察者到broker中,失敗

關(guān)聯(lián)觀察者到broker中,并只觀察多次

我創(chuàng)建的觀察者之后,需要通過(guò)此接口將觀察者關(guān)聯(lián)到broker中。當(dāng)發(fā)布者發(fā)布事件,可以通過(guò)broker找到對(duì)用的觀察者。使用該接口觀察者只觀察多次事件。

reb_statusbroker_observer_attach(observer_base*obs);

「參數(shù)」 「描述」
obs 觀察者對(duì)象
「返回」 ——
REB_OK 關(guān)聯(lián)觀察者到broker中,成功
REB_ERROR 關(guān)聯(lián)觀察者到broker中,失敗

從broker中脫離觀察者

reb_statusbroker_observer_detach(observer_base*obs);

「參數(shù)」 「描述」
obs 觀察者對(duì)象
「返回」 ——
REB_OK 觀察者從broker中脫離,成功
REB_ERROR 觀察者從broker中脫離,失敗

observer接口

接口 說(shuō)明
observer_signal_create 創(chuàng)建信號(hào)模式的觀察者,只接收事件信號(hào),不傳輸數(shù)據(jù)的觀察者
observer_signal_wait 信號(hào)模式的觀察者,等待同步信號(hào)
observer_callback_create 創(chuàng)建回調(diào)模式的觀察者
observer_task_create 創(chuàng)建任務(wù)模式的觀察者
observer_delete 刪除觀察者

創(chuàng)建信號(hào)模式的觀察者

該接口是創(chuàng)建信號(hào)模式的觀察者,它只接收事件信號(hào),不傳輸數(shù)據(jù)的。

observer_base*observer_signal_create(uint16_ttype,uint16_tsub_type);

「參數(shù)」 「描述」
type 觀察者觀察的主事件類型
sub_type 觀察者觀察的次事件類型
「返回」 ——
obs 觀察者創(chuàng)建成功
NULL 觀察者創(chuàng)建失敗

信號(hào)模式的觀察者,等待同步信號(hào)

該接口是信號(hào)模式的觀察者,用戶層需要通過(guò)一個(gè)任務(wù)監(jiān)聽(tīng)觀察事件的同步信號(hào)接口。

reb_statusobserver_signal_wait(observer_base*base,reb_time_ttimeout);

「參數(shù)」 「描述」
base 觀察者對(duì)象
timeout 觀察事件的超時(shí)事件
「返回」 ——
REB_OK 觀察到對(duì)應(yīng)事件
OTHER 觀察失敗

創(chuàng)建回調(diào)模式的觀察者

該接口是創(chuàng)建回調(diào)模式的觀察者,當(dāng)事件產(chǎn)生時(shí),broker會(huì)通過(guò)回調(diào)的方式通知觀察者事件的到來(lái)。

observer_base*observer_callback_create(uint16_ttype,
uint16_tsub_type,
obs_callback_cbcb,
void*arg);

「參數(shù)」 「描述」
type 觀察者觀察的主事件類型
sub_type 觀察者觀察的次事件類型
cb 事件產(chǎn)生時(shí),回調(diào)的接口函數(shù)
arg 回調(diào)函數(shù)的用戶數(shù)據(jù)
「返回」 ——
obs 觀察者創(chuàng)建成功
NULL 觀察者創(chuàng)建失敗

創(chuàng)建任務(wù)模式的觀察者

該接口是創(chuàng)建任務(wù)模式的觀察者,當(dāng)事件產(chǎn)生時(shí),broker會(huì)通過(guò)創(chuàng)建一個(gè)線程,然后由獨(dú)立的線程將事件通知給觀察者。

observer_base*observer_task_create(uint16_ttype,
uint16_tsub_type,
obs_task_cbrun,
void*arg,
uint32_tstack_size,
uint32_tprio);

「參數(shù)」 「描述」
type 觀察者觀察的主事件類型
sub_type 觀察者觀察的次事件類型
run 事件產(chǎn)生時(shí),線程的處理函數(shù)
arg 線程處理函數(shù)的用戶數(shù)據(jù)
stack_size 線程的??臻g大小
prio 線程的優(yōu)先級(jí)
「返回」 ——
obs 觀察者創(chuàng)建成功
NULL 觀察者創(chuàng)建失敗

從broker中脫離觀察者

reb_statusobserver_delete(observer_base*base);

「參數(shù)」 「描述」
base 觀察者對(duì)象
「返回」 ——
REB_OK 觀察者刪除成功
REB_ERROR 觀察者刪除失敗

publisher接口

接口 說(shuō)明
publisher_factory_create 創(chuàng)建發(fā)布者工廠
publisher_send 發(fā)布者默認(rèn)發(fā)送消息
publisher_send_with_free 發(fā)布者默認(rèn)發(fā)送消息,發(fā)送完成之后把消息緩沖刪除
publisher_urgent_send 發(fā)布者發(fā)送緊急消息
publisher_urgent_send_with_free 發(fā)布者發(fā)送緊急消息,發(fā)送完成之后把消息緩沖刪除

創(chuàng)建發(fā)布者工廠

該接口是創(chuàng)建發(fā)布者工廠,提供事件隊(duì)列,使發(fā)布消息處于非阻塞式發(fā)送

reb_statuspublisher_factory_create(pub_notifynotify);

「參數(shù)」 「描述」
notify 事件通知回調(diào),當(dāng)發(fā)布者發(fā)布消息之后,通過(guò)回調(diào)通知broker
「返回」 ——
REB_OK 發(fā)布者工廠創(chuàng)建成功
REB_ERROR 發(fā)布者工廠創(chuàng)建失敗

發(fā)布者默認(rèn)發(fā)送消息

該接口是發(fā)布者發(fā)布事件接口,它是采用先進(jìn)先出的方式發(fā)送消息

reb_statuspublisher_send(uint16_ttype,uint16_tsub_type,
uint32_tdata,reb_time_ttimeout);

「參數(shù)」 「描述」
type 發(fā)布消息的主事件類型
sub_type 發(fā)布消息的次事件類型
data 發(fā)布消息的數(shù)據(jù)
timeout 發(fā)布消息的超時(shí)時(shí)間
「返回」 ——
REB_OK 發(fā)布消息成功
OTHER 發(fā)布消息失敗

發(fā)布者默認(rèn)發(fā)送消息,發(fā)送完成之后把消息緩沖刪除

該接口是發(fā)布者發(fā)布事件接口,它是采用先進(jìn)先出的方式發(fā)送消息,并且將消息發(fā)送給所有觀察者之后,數(shù)據(jù)的內(nèi)存會(huì)執(zhí)行釋放。

reb_statuspublisher_send_with_free(uint16_ttype,uint16_tsub_type,
uint32_tdata,reb_time_ttimeout);

「參數(shù)」 「描述」
type 發(fā)布消息的主事件類型
sub_type 發(fā)布消息的次事件類型
data 發(fā)布消息的數(shù)據(jù)
timeout 發(fā)布消息的超時(shí)時(shí)間
「返回」 ——
REB_OK 發(fā)布消息成功
OTHER 發(fā)布消息失敗

發(fā)布者發(fā)送緊急消息

該接口是發(fā)布者發(fā)布事件接口,它是采用插隊(duì)的方式發(fā)送消息,它會(huì)將發(fā)布的消息插入消息隊(duì)列的頭部。

reb_statuspublisher_urgent_send(uint16_ttype,uint16_tsub_type,
uint32_tdata,reb_time_ttimeout);

「參數(shù)」 「描述」
type 發(fā)布消息的主事件類型
sub_type 發(fā)布消息的次事件類型
data 發(fā)布消息的數(shù)據(jù)
timeout 發(fā)布消息的超時(shí)時(shí)間
「返回」 ——
REB_OK 發(fā)布消息成功
OTHER 發(fā)布消息失敗

發(fā)布者發(fā)送緊急消息,發(fā)送完成之后把消息緩沖刪除

該接口是發(fā)布者發(fā)布事件接口,它它是采用插隊(duì)的方式發(fā)送消息,它會(huì)將發(fā)布的消息插入消息隊(duì)列的頭部。并且將消息發(fā)送給所有觀察者之后,數(shù)據(jù)的內(nèi)存會(huì)執(zhí)行釋放。

reb_statuspublisher_urgent_send_with_free(uint16_ttype,uint16_tsub_type,
uint32_tdata,reb_time_ttimeout);

「參數(shù)」 「描述」
type 發(fā)布消息的主事件類型
sub_type 發(fā)布消息的次事件類型
data 發(fā)布消息的數(shù)據(jù)
timeout 發(fā)布消息的超時(shí)時(shí)間
「返回」 ——
REB_OK 發(fā)布消息成功
OTHER 發(fā)布消息失敗

REB驗(yàn)證

創(chuàng)建三個(gè)不同模式的觀察者,并關(guān)聯(lián)到broker中。

通過(guò)多次不發(fā)布事件,查看觀察者是否能接收到事件。

#include"rtthread.h"
#include"reb_broker.h"
#include"reb_observer.h"
#include"reb_publisher.h"

observer_base*obs_signal;
observer_base*obs_call;
observer_base*obs_task;

voidsig_thread_handle(void*arg)//信號(hào)模式觀察者監(jiān)聽(tīng)同步信號(hào)
{
while(1){
if(observer_signal_wait(obs_signal,RT_WAITING_FOREVER)==REB_OK){
rt_kprintf("signal:recvsuccessrn");
}
}
}

voidobs_callback(uint32_tevent,uint32_tdata,void*arg)//回調(diào)模式觀察者處理函數(shù)
{
rt_kprintf("call:event:0x%08x,data:%srn",event,(char*)data);
}

voidobs_task_fun(uint32_tevent,uint32_tdata,void*arg)//任務(wù)模式觀察者任務(wù)處理函數(shù)
{
rt_kprintf("task:event:0x%08x,data:%srn",event,(char*)data);
}

intreb_init(void)
{
rt_thread_tsignal_thread=NULL;

broker_create();//broker創(chuàng)建

obs_signal=observer_signal_create(1,REB_ALL_MINOR_TYPE);//創(chuàng)建信號(hào)模式觀察者

signal_thread=rt_thread_create("sig_thread",sig_thread_handle,NULL,1024,10,20);//創(chuàng)建線程,等待信號(hào)模式下的事件
rt_thread_startup(signal_thread);

obs_call=observer_callback_create(1,REB_ALL_MINOR_TYPE,obs_callback,NULL);//創(chuàng)建回調(diào)模式觀察者

obs_task=observer_task_create(1,REB_ALL_MINOR_TYPE,obs_task_fun,NULL,1024,15);//創(chuàng)建任務(wù)模式觀察者

broker_observer_attach(obs_signal);//關(guān)聯(lián)信號(hào)模式觀察者
broker_observer_attach(obs_call);//關(guān)聯(lián)回調(diào)模式觀察者
broker_observer_attach_once(obs_task);//關(guān)聯(lián)任務(wù)模式觀察者

returnRT_EOK;
}
INIT_COMPONENT_EXPORT(reb_init);

intreb_test(void)
{
char*data="RiceChen";
publisher_send(1,1,(int)data,1000);//發(fā)布事件
publisher_send(1,2,(int)data,1000);//發(fā)布事件
publisher_send(1,3,(int)data,1000);//發(fā)布事件
}
MSH_CMD_EXPORT(reb_test,RiceEventbrokertest);
9c1e5e4e-6c0f-11ee-b3e3-92fbcf53809c.jpg

REB總結(jié)

REB優(yōu)點(diǎn):

REB提供了多種的模式的觀察者,可以根據(jù)需求選擇不同模式的觀察者。

REB的發(fā)布者可以支持緊急事件發(fā)布和非緊急事件發(fā)送,保證了事件的及時(shí)響應(yīng)。

REB增加了OSAL層,使其不依賴于任何的平臺(tái),可以很方便的移植到其他平臺(tái)。

REB缺點(diǎn):

REB的事件處理采用串行的方式,當(dāng)事件積累多了,負(fù)載會(huì)比較大(后續(xù)優(yōu)化)。

REB已經(jīng)被合并到RT-THREAD軟件包中,并且得到RT-THREAD技術(shù)總監(jiān)的認(rèn)可。開(kāi)源鏈接:https://github.com/RiceChen0/reb

9c3414c8-6c0f-11ee-b3e3-92fbcf53809c.png ?

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 框架
    +關(guān)注

    關(guān)注

    0

    文章

    403

    瀏覽量

    17502
  • 模塊化
    +關(guān)注

    關(guān)注

    0

    文章

    332

    瀏覽量

    21359
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4790

    瀏覽量

    68654
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    為什么要開(kāi)發(fā)模塊化測(cè)試框架?

    為什么要開(kāi)發(fā)模塊化測(cè)試框架?具體該怎么做?
    發(fā)表于 08-08 06:06

    CC2540廣播角色和觀察者角色切換代碼怎么編寫?

    希望一個(gè)CC2540先通過(guò)觀察者角色獲取其他廣播的廣播數(shù)據(jù),然后在切換為廣播角色將這些數(shù)據(jù)廣播給另外一個(gè)觀察者?這樣就需要編程實(shí)現(xiàn)觀察者
    發(fā)表于 03-16 10:27

    RN4020觀察者模式無(wú)法正常工作怎么回事

    中心,支持MLDP,并使UART流控制R,1//重新引導(dǎo),使更改生效J,1//觀察者模式你對(duì)這個(gè)問(wèn)題有什么想法?謝謝,弗朗西斯科
    發(fā)表于 04-22 09:03

    屬性觀察者的特點(diǎn)

    屬性觀察者,類似于觸發(fā)器。用來(lái)監(jiān)視屬性的除初始之外的屬性值變化,當(dāng)屬性值發(fā)生改變時(shí)可以對(duì)此作出響應(yīng)。有如下特點(diǎn): 1,不僅可以在屬性值改變后觸發(fā)didSet,也可以在屬性值改變前觸發(fā)willSet
    發(fā)表于 11-04 07:10

    觀察者模式在嵌入式編程設(shè)計(jì)中有何作用

    觀察者模式是最常見(jiàn)的模式之一。這種模式提供一種方法來(lái)時(shí)對(duì)象“監(jiān)聽(tīng)”其他對(duì)象,而不需要修改任何數(shù)據(jù)服務(wù)器。在嵌入式領(lǐng)域,這意味著數(shù)據(jù)能夠很容易分享給其他元素。
    發(fā)表于 12-22 08:31

    基于觀察者模式的屏幕布局控件設(shè)計(jì)

    觀察者模式作為設(shè)計(jì)模式中行為模式的一種,解決了上述具有一對(duì)多依賴關(guān)系對(duì)象重用問(wèn)題。文中在分析觀察者模式
    發(fā)表于 02-13 16:20 ?4次下載
    基于<b class='flag-5'>觀察者</b><b class='flag-5'>模式</b>的屏幕布局控件設(shè)計(jì)

    全面提升自動(dòng)測(cè)試,NI TestStand 2012新模塊化框架

    NI TestStand 2012采用全新的模塊化框架,能夠簡(jiǎn)化自動(dòng)測(cè)試的開(kāi)發(fā)和報(bào)告生成。
    發(fā)表于 11-06 17:42 ?1779次閱讀

    Java設(shè)計(jì)模式分析之觀察者

    觀察者模式的流程跟報(bào)紙訂閱方式一致,即:觀察者模式=出版+訂閱,只是名稱不一樣,出版
    發(fā)表于 09-26 17:36 ?0次下載

    在 Java8 環(huán)境下實(shí)現(xiàn)觀察者模式的實(shí)例分析

    觀察者(Observer)模式又名發(fā)布-訂閱(Publish/Subscribe)模式,是四人組(GoF,即 Erich Gamma、Richard Helm、Ralph Johnson
    發(fā)表于 10-12 16:09 ?0次下載
    在 Java8 環(huán)境下實(shí)現(xiàn)<b class='flag-5'>觀察者</b><b class='flag-5'>模式</b>的實(shí)例分析

    基于AT32(STM32)單片機(jī)的模塊化代碼之——按鍵代碼模塊化

    基于AT32(STM32)單片機(jī)的模塊化代碼之按鍵模塊化1.環(huán)境介紹平臺(tái):AT32F415單片機(jī),雅特力公司的AT32系列單片機(jī)其實(shí)跟STM32系列單片機(jī)大同小異,包括庫(kù)函數(shù)等基本都是一樣的,所以
    發(fā)表于 11-19 10:06 ?37次下載
    基于AT32(STM32)單片機(jī)的<b class='flag-5'>模塊化</b><b class='flag-5'>代碼</b>之——按鍵<b class='flag-5'>代碼</b><b class='flag-5'>模塊化</b>

    基于AT32(STM32)單片機(jī)的模塊化代碼之——ADC代碼模塊化

    基于AT32(STM32)單片機(jī)的模塊化代碼之——ADC代碼模塊化1.環(huán)境介紹平臺(tái):AT32F415單片機(jī),雅特力公司的AT32系列單片機(jī)其實(shí)跟STM32系列單片機(jī)大同小異,包括庫(kù)函數(shù)
    發(fā)表于 11-19 10:36 ?17次下載
    基于AT32(STM32)單片機(jī)的<b class='flag-5'>模塊化</b><b class='flag-5'>代碼</b>之——ADC<b class='flag-5'>代碼</b><b class='flag-5'>模塊化</b>

    設(shè)計(jì)模式行為型:觀察者模式

    定義對(duì)象之間的一種一對(duì)多依賴關(guān)系,使得每一個(gè)對(duì)象發(fā)生狀態(tài)的變化時(shí),其相關(guān)依賴對(duì)象皆得到通知并被自動(dòng)更新,又稱為發(fā)布-訂閱模式、模型-視圖模式、源-監(jiān)聽(tīng)器模式或從屬
    的頭像 發(fā)表于 06-07 16:56 ?678次閱讀
    設(shè)計(jì)<b class='flag-5'>模式</b>行為型:<b class='flag-5'>觀察者</b><b class='flag-5'>模式</b>

    觀察者模式,超詳細(xì)!

    觀察者模式建議你為發(fā)布類添加訂閱機(jī)制, 讓每個(gè)對(duì)象都能訂閱或取消訂閱發(fā)布事件流。 不要害怕! 這并不像聽(tīng)上去那么復(fù)雜。 實(shí)際上, 該機(jī)制包括 1) 一個(gè)用于存儲(chǔ)訂閱
    的頭像 發(fā)表于 08-21 16:06 ?1216次閱讀
    <b class='flag-5'>觀察者</b><b class='flag-5'>模式</b>,超詳細(xì)!

    一文解析BLE觀察者模式回調(diào)機(jī)制

    nRF5 SDK從版本14開(kāi)始,對(duì)事件回調(diào)機(jī)制做了更新,引入了觀察者模式,以解耦不同BLE Layer對(duì)BLE事件的回調(diào)函數(shù)。
    的頭像 發(fā)表于 11-27 10:07 ?1041次閱讀
    一文解析BLE<b class='flag-5'>觀察者</b><b class='flag-5'>模式</b>回調(diào)機(jī)制

    什么是觀察者設(shè)計(jì)模式?Golang中的觀察者模式介紹

    當(dāng)涉及到訂單處理系統(tǒng)時(shí),觀察者設(shè)計(jì)模式可以用于實(shí)現(xiàn)訂單狀態(tài)的變化和通知。
    的頭像 發(fā)表于 01-08 10:08 ?431次閱讀