淺談Python 責(zé)任鏈模式
介紹
責(zé)任鏈模式是一種行為型設(shè)計(jì)模式,它允許多個對象以鏈?zhǔn)降男问揭来翁幚碚埱?,直到請求被處理或者無處理對象為止
實(shí)現(xiàn)方式
責(zé)任鏈模式由多個處理器組成,每個處理器都可以處理一種請求。如果當(dāng)前處理器無法處理請求,它將把請求傳遞給下一個處理器,直到請求被處理或者沒有處理器可以處理為止。
案例
假設(shè)我們正在開發(fā)一個電子商務(wù)平臺,現(xiàn)在需要實(shí)現(xiàn)一個購物車功能。當(dāng)用戶添加商品到購物車中時,需要進(jìn)行以下驗(yàn)證
- 商品是否存在
- 商品庫存是否充足
- 商品是否已經(jīng)下架
我們可以使用責(zé)任鏈模式來實(shí)現(xiàn)這個購物車功能。首先定義一個處理器基類
class CartValidator: ? ? def __init__(self, next_validator=None): ? ? ? ? self.next_validator = next_validator ? ? def validate(self, item): ? ? ? ? if self.next_validator: ? ? ? ? ? ? return self.next_validator.validate(item) ? ? ? ? return True
這個基類包含了一個next_validator屬性,表示后繼處理器,以及一個validate方法,用于驗(yàn)證商品是否合法。如果存在后繼處理器,則將驗(yàn)證請求傳遞給后繼處理器。
接下來,我們可以定義三個具體的驗(yàn)證處理器,分別驗(yàn)證商品是否存在、商品庫存是否充足以及商品是否已經(jīng)下架
# 模擬
is_product_exist = True ?# 判斷商品是否存在
is_product_stock_enough = True ?# 判斷商品庫存是否充足
is_product_on_sale = True ?# 判斷商品是否已經(jīng)下架
class ProductExistValidator(CartValidator):
? ? def validate(self, item):
? ? ? ? # 判斷商品是否存在
? ? ? ? # if not is_product_exist(item):
? ? ? ? if not is_product_exist:
? ? ? ? ? ? print('商品不存在')
? ? ? ? ? ? return False
? ? ? ? return super().validate(item)
class ProductStockValidator(CartValidator):
? ? def validate(self, item):
? ? ? ? # 判斷商品庫存是否充足
? ? ? ? # if not is_product_stock_enough(item):
? ? ? ? if not is_product_stock_enough:
? ? ? ? ? ? print('庫存不足')
? ? ? ? ? ? return False
? ? ? ? return super().validate(item)
class ProductStatusValidator(CartValidator):
? ? def validate(self, item):
? ? ? ? # 判斷商品是否已經(jīng)下架
? ? ? ? # if not is_product_on_sale(item):
? ? ? ? if not is_product_on_sale:
? ? ? ? ? ? print('商品已下架')
? ? ? ? ? ? return False
? ? ? ? return super().validate(item)
product_validator_chain = ProductExistValidator(ProductStockValidator(ProductStatusValidator()))
def add_to_cart(item):
? ? if product_validator_chain.validate(item):
? ? ? ? # 添加商品到購物車中
? ? ? ? # add_item_to_cart(item)
? ? ? ? print("添加成功", item)
? ? ? ? pass
? ? else:
? ? ? ? # 商品驗(yàn)證失敗
? ? ? ? print("商品驗(yàn)證失敗")這三個處理器都繼承自CartValidator類,并覆蓋了validate方法,實(shí)現(xiàn)了具體的商品驗(yàn)證邏輯。如果商品驗(yàn)證通過,則調(diào)用super()
.validate(item)方法,將驗(yàn)證請求傳遞給下一個處理器。
最后,我們可以將這三個處理器組成一個責(zé)任鏈:
product_validator_chain = ProductExistValidator(ProductStockValidator(ProductStatusValidator()))
測試
正常測試
add_to_cart("IPhone14 pro")
輸出結(jié)果
添加成功 IPhone14 pro
庫存不足測試
# 模擬庫存不足
is_product_stock_enough = False
add_to_cart("IPhone14 pro")
輸出結(jié)果
庫存不足
商品驗(yàn)證失敗
使用場景
多個對象需要處理同一種請求,但處理的順序和方式不同。例如,一個在線商店需要對訂單進(jìn)行風(fēng)險評估,評估過程包括多個步驟,如檢查訂單是否來自欺詐用戶、檢查收貨地址是否存在風(fēng)險等。每個步驟可以使用一個處理器來處理,這些處理器可以組成一個責(zé)任鏈,對訂單進(jìn)行逐步風(fēng)險評估。
對象不知道該由哪個處理器處理請求,需要動態(tài)確定處理器。java中的web框架的過濾器,需要根據(jù)請求的URL來選擇合適的處理器,處理器可以根據(jù)自身能力來決定是否能夠處理請求。
動態(tài)擴(kuò)展。在系統(tǒng)中需要動態(tài)添加或刪除處理器,同時保證請求可以被正確處理。例如,一個安全檢查系統(tǒng)需要根據(jù)系統(tǒng)的安全策略來動態(tài)添加或刪除安全檢查處理器,同時保證請求可以被正確處理。
到此這篇關(guān)于淺談Python 責(zé)任鏈模式的文章就介紹到這了,更多相關(guān)Python 責(zé)任鏈模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何利用Python matplotlib繪制雷達(dá)圖
這篇文章主要給大家介紹了關(guān)于如何利用Python matplotlib繪制雷達(dá)圖的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
Pygame實(shí)戰(zhàn)練習(xí)之炸彈人學(xué)院游戲
炸彈人學(xué)院想必是很多人童年時期的經(jīng)典游戲,我們依舊能記得抱個老人機(jī)娛樂的場景,下面這篇文章主要給大家介紹了關(guān)于如何利用python寫一個簡單的炸彈人學(xué)院小游戲的相關(guān)資料,需要的朋友可以參考下2021-09-09
Python3數(shù)據(jù)庫操作包pymysql的操作方法
這篇文章主要介紹了Python3數(shù)據(jù)庫操作包pymysql的操作方法,文章通過實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-07-07
Python如何篩選序列中的元素的方法實(shí)現(xiàn)
這篇文章主要介紹了Python如何篩選序列中的元素的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
python利用while求100內(nèi)的整數(shù)和方式
這篇文章主要介紹了 python利用while求100內(nèi)的整數(shù)和方式,下面文章要描述的內(nèi)容有1到100的和、1到100內(nèi)的偶數(shù)和、1到100內(nèi)的奇數(shù)和,具體詳細(xì)內(nèi)容,需要的朋友可以參考一下2021-11-11
Python通用循環(huán)的構(gòu)造方法實(shí)例分析
這篇文章主要介紹了Python通用循環(huán)的構(gòu)造方法,結(jié)合實(shí)例形式分析了Python常見的交互循環(huán)、哨兵循環(huán)、文件循環(huán)、死循環(huán)等實(shí)現(xiàn)與處理技巧,需要的朋友可以參考下2018-12-12

