近日在公司領(lǐng)到一個(gè)小需求,需要對(duì)之前已有的試用用戶申請(qǐng)規(guī)則進(jìn)行拓展。我們的場(chǎng)景大概如下所示:
按照上述的條件我們可以得出的結(jié)論是:
咱們的主要流程主要是基于 and 或者 or 的關(guān)系。
如果有一個(gè)不匹配的話,其實(shí)咱們后續(xù)的流程是不用執(zhí)行的,就是需要具備一個(gè)短路的功能。
對(duì)于目前的現(xiàn)狀來(lái)說,我如果在原有的基礎(chǔ)上來(lái)改,只要稍微注意一下解決需求不是很大的問題,但是說后面可維護(hù)性非常差。
后面經(jīng)過權(quán)衡過后,我還是決定將這個(gè)部分進(jìn)行重構(gòu)一下。
規(guī)則執(zhí)行器
針對(duì)這個(gè)需求,我首先梳理了一下咱們規(guī)則執(zhí)行器大概的設(shè)計(jì), 然后我設(shè)計(jì)了一個(gè) V1 版本和大家一起分享一下,如果大家也有這樣的case 可以給我分享留言,下面部分主要是設(shè)計(jì)和實(shí)現(xiàn)的流程和 code。
規(guī)則執(zhí)行器的設(shè)計(jì)
對(duì)于規(guī)則的抽象并實(shí)現(xiàn)規(guī)則
執(zhí)行器構(gòu)建
執(zhí)行器的調(diào)用
總結(jié)
規(guī)則執(zhí)行器的優(yōu)點(diǎn)和缺點(diǎn)
優(yōu)點(diǎn):
比較簡(jiǎn)單,每個(gè)規(guī)則可以獨(dú)立,將規(guī)則,數(shù)據(jù),執(zhí)行器拆分出來(lái),調(diào)用方比較規(guī)整;
我在 Rule 模板類中定義 convert 方法做參數(shù)的轉(zhuǎn)換這樣可以能夠,為特定 rule 需要的場(chǎng)景數(shù)據(jù)提供拓展。
缺點(diǎn):
上下 rule 有數(shù)據(jù)依賴性,如果直接修改公共傳輸對(duì)象 dto這樣設(shè)計(jì)不是很合理,建議提前構(gòu)建數(shù)據(jù)。
審核編輯:湯梓紅
-
執(zhí)行器
+關(guān)注
關(guān)注
5文章
377瀏覽量
19358
原文標(biāo)題:還在寫大量 if 來(lái)判斷?試試用一個(gè)規(guī)則執(zhí)行器來(lái)替代它
文章出處:【微信號(hào):玩轉(zhuǎn)單片機(jī)與嵌入式,微信公眾號(hào):玩轉(zhuǎn)單片機(jī)與嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論