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

