事件驅(qū)動和消息驅(qū)動

消息驅(qū)動和事件驅(qū)動很類似,都是先有一個事件,然后產(chǎn)生一個相應(yīng)的消息,再把消息放入消息隊(duì)列,由需要的項(xiàng)目獲取。他們的區(qū)別是消息是誰產(chǎn)生的

消息驅(qū)動:鼠標(biāo)管自己點(diǎn)擊不需要和系統(tǒng)有過多的交互,消息由系統(tǒng)(第三方)循環(huán)檢測,來捕獲并放入消息隊(duì)列。消息對于點(diǎn)擊事件來說是被動產(chǎn)生的,高內(nèi)聚。

事件驅(qū)動:鼠標(biāo)點(diǎn)擊產(chǎn)生點(diǎn)擊事件后要向系統(tǒng)發(fā)送消息“我點(diǎn)擊了”的消息,消息是主動產(chǎn)生的。再發(fā)送到消息隊(duì)列中。

ps:二者都可以根據(jù)消息隊(duì)列判斷有沒有事件,然后沒有的話也都可以進(jìn)入睡眠。

事件模式耦合高,同模塊內(nèi)好用;消息模式耦合低,跨模塊好用。事件模式集成其它語言比較繁瑣,消息模式集成其他語言比較輕松。事件是侵入式設(shè)計(jì),霸占你的主循環(huán);消息是非侵入式設(shè)計(jì),將主循環(huán)該怎樣設(shè)計(jì)的自由留給用戶。如果你在設(shè)計(jì)一個東西舉棋不定,那么你可以參考win32的GetMessage,本身就是一個藕合度極低的接口,又足夠自由,接口任何語言都很方便,具體應(yīng)用場景再在其基礎(chǔ)上封裝成事件并不是難事,接口耦合較低,即便哪天事件框架調(diào)整,修改外層即可,不會傷經(jīng)動骨。而如果直接實(shí)現(xiàn)成事件,那就完全反過來了。

Jfinal中dreamlu的事件驅(qū)動插件Jfinal-event
準(zhǔn)備:先新建一個插件。初始化時(shí),掃描指定包里面的有@Listen.classannotion的類放入List中,然后從每一個監(jiān)聽器的泛型type中獲取事件類。生成一個map容器,其中鍵是事件,值是監(jiān)聽器。然后初始化EventKit(將上面的map傳入),方便接下來使用。
工作:在需要監(jiān)聽的地方用EventKit.postEvent(XXXEvent.class)表示發(fā)生了一個XXXEvent.class事件,然后EventKit從之前的map中通過XXXEvent.class知道有哪些監(jiān)聽器會監(jiān)聽這個事件,然后建立一個新的線程執(zhí)行這些監(jiān)聽器的新的實(shí)例并start()。

http://blog.csdn.net/haonan9122/article/details/5753842

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,653評論 19 139
  • (git上的源碼:https://gitee.com/rain7564/spring_microservices_...
    sprainkle閱讀 9,518評論 8 17
  • 遇見s先生的時(shí)候,小魚剛結(jié)束一場長長的初愛和一場短暫到分秒計(jì)算的婚姻,當(dāng)然是與同一個人,所謂的糾纏不休到老死不相...
    楊小魚的千千結(jié)閱讀 429評論 0 0
  • 甜甜的,舔著嘴角的蜜汁醒來 一不小心敲碎的棒棒糖卻怎么也拼不回去 想回到那個夢里 卻怎么也推不開門。 群魔在天際的...
    達(dá)洱文閱讀 200評論 0 0
  • 一、 既然注定不能找回,不如轉(zhuǎn)過頭繼續(xù)前行,聽到一生所愛的歌響起, 你感慨萬千卻再也哭不出來,竟只有無奈一笑,一生...
    王先森Beckham閱讀 2,072評論 0 5

友情鏈接更多精彩內(nèi)容