c++ 類函數(shù)作為模板參數(shù)實現(xiàn)方式詳解
需求背景
DB操作有四種基本操作:Insert、Update、Delete和Query,每種操作需要進行功能增強(eg:支持重試、權(quán)限校驗等),最粗暴的實現(xiàn)就是改動原有接口實現(xiàn),在實現(xiàn)中加入增強邏輯,這種方式對代碼侵入性過高,而且無法控制該邏輯是否需要,如果不需要的話又得重新修改代碼實現(xiàn)。
可以用裝飾者設(shè)計模式對原有接口做一層包裝,然后在包裝層里注入增強實現(xiàn)邏輯,偽碼表現(xiàn)形式:
Status Insert(Args args...); Status Update(Args args...); Status Delete(Args args...); Status Query(Args args...); Status Wapper(...){ // 增強邏輯實現(xiàn) ... // 調(diào)用原有函數(shù) Insert(Args args...) // 返回處理結(jié)果 ... }
實現(xiàn)方式
對于這種通用的增強邏輯及包裝形式,很適合用模板作為統(tǒng)一實現(xiàn),簡化代碼邏輯,并增強后期維護,對于上述場景,有如下兩種模板實現(xiàn)方式:
struct + operator
class DbWapper : public DbOperation{ public: // 繼承方法 Status Insert(Args args...) override; Status Update(Args args...) override; Status Delete(Args args...) override; Status Query(Args args...) override; private: DbOperation *m_dbOperation; template <typename Func, typename... Args> Status Wapper(Func func, Args &&...args) { // 調(diào)用原有的函數(shù)邏輯 Status status = func(std::forward<Args>(args)...); // 增強邏輯實現(xiàn) ... return status; } } Status Insert(Args args...) { // 利用struct + operator實現(xiàn)函數(shù)包裝 struct InsertFunc { DbOperation *dbOperation; Status operator()(Args args...) const { // 調(diào)用原有邏輯 return dbOperation->Insert(args...); } } insertFunc{m_dbOperation}; // 將函數(shù)包裝作為function傳入增強邏輯 return Wapper(insertFunc, args...); }
Pass Function Signature
觀察上一種實現(xiàn)方案,發(fā)現(xiàn)struct和operator只是為了構(gòu)造一種函數(shù)參數(shù),便于模板調(diào)用原有邏輯,所以我們可以嘗試消除struct,讓模板只接受具體的函數(shù)簽名,就可以極大簡化實現(xiàn)邏輯,具體實現(xiàn)如下:
class DbWapper : public DbOperation{ public: // 繼承方法 Status Insert(Args args...) override; Status Update(Args args...) override; Status Delete(Args args...) override; Status Query(Args args...) override; private: DbOperation *m_dbOperation; template <typename... Args0, typename... Args1> Status Wapper(Status (DbOperation::*method)(Args0...), Args1 &&...args) { // 調(diào)用原有的函數(shù)邏輯 Status status = (m_dbOperation->*method)(std::forward<Args1>(args)...); // 增強邏輯實現(xiàn) ... return status; } } Status Insert(Args args...) { // 傳入具體的函數(shù)簽名 return Wapper((Status(DbOperation::*)(Insert函數(shù)簽名))(&DbOperation::Insert), args...); }
Get busy living or get busy dying.
到此這篇關(guān)于c++ 類函數(shù)作為模板參數(shù)實現(xiàn)方式的文章就介紹到這了,更多相關(guān)c++ 類函數(shù)作為模板參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言中實現(xiàn)“17進制”轉(zhuǎn)“10進制”實例代碼
這篇文章主要介紹了C語言中實現(xiàn)“17進制”轉(zhuǎn)“10進制”實例代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05