C++泛型模板約束深入講解
CPP參考:(新標(biāo)準(zhǔn))
模板對于類型的約束:
約束 template_get_size 泛型T只允許接受類型:list<T>,其實(shí)為 C/C++ 泛型模板例化特性,但與泛型模板例化略微有些區(qū)別,因?yàn)槭菐Х盒皖愋图s束條件的特例化。
template<typename T>
class list {
public:
int count = 0;
};
template<typename T>
struct template_get_size;
template<typename T>
struct template_get_size<list<T> > {
inline std::size_t size(list<T>& v) {
return v.count;
}
};
int main(int argc, const char* argv[]) noexcept {
list<int> list_;
list_.count = 100;
template_get_size<list<int> > list_get_size_;
printf("%d\n", list_get_size_.size(list_));
return 0;
}但,template_get_size<int> 仍然可以嘗試編譯,從語法層面沒有問題,但會編譯失敗,原因:C/C++ 使用不完整的類型。
人們無法在編譯期間來增加更多檢查約束的有效性。
例一:
template<typename T>
struct template_get_size {
static_assert(false, "Type constraints of generic templates are violated.");
};例二:
template<typename T>
struct template_get_size;
template<typename T>
struct template_get_size<T> {
static_assert(false, "Type constraints of generic templates are violated.");
};上述適用于泛型模板類/結(jié)構(gòu)體,同理泛型模板函數(shù)仍可以增加泛型約束,只是沒有辦法向模板類型一樣可以明確的約束T到底需要是什么類型,這取決于模板函數(shù)內(nèi)部的實(shí)現(xiàn),根代碼粘合劑差不多,但不意味著不能精確限制那些T類型。
泛型模板類型例化:
class A {};
class B : public A {};
template<typename T>
class say;
template<>
class say<A> {};例如:人們需要T是一個(gè)指針,那么有以下幾種方法約束:
案例一:
template<typename T>
void foo(const T* v) {}案例二:
template<typename T>
void foo(const T& v) {
typedef typename std::remove_pointer<T>::type element_type;
element_type* p = NULL;
}如果:
人們需要T是一個(gè)基類,那么這種似乎不需要模板來實(shí)現(xiàn),如果是模板大約是這樣的形式:
約束T必須是A類或其派生類型,但使用該模板函數(shù)的開放人員只有兩個(gè)途徑搞清楚T到底被約束為什么。
即:1、函數(shù)注釋上明確T的約束類型,2、查看模板函數(shù)的內(nèi)部實(shí)現(xiàn),不像C#中明確為泛型模板類型 T 增加顯示一致性的 where T 約束條件。
class A {};
class B : public A {};
template<typename T>
void foo(const T* v) {
A* a = const_cast<T*>(v);
}
int main(int argc, const char* argv[]) noexcept {
B b;
foo(&b);
return 0;
}一個(gè)好的建議是:
每個(gè)泛型模板的類型約束都應(yīng)在類型/函數(shù)注釋上明確指出,這樣使用模板的開發(fā)人員不需要嘗試預(yù)編譯代碼或閱讀模板代碼實(shí)現(xiàn)來判定模板代碼約束條件。
到此這篇關(guān)于C++泛型模板約束深入講解的文章就介紹到這了,更多相關(guān)C++泛型模板約束內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何用C++求兩個(gè)數(shù)的最大公約數(shù)和最小公倍數(shù)
最大公約數(shù)是指兩個(gè)或多個(gè)整數(shù)共有約數(shù)中,最大的一個(gè)約數(shù),常用的方法是歐幾里得算法,也叫輾轉(zhuǎn)相除法,下面這篇文章主要給大家介紹了關(guān)于如何用C++求兩個(gè)數(shù)的最大公約數(shù)和最小公倍數(shù)的相關(guān)資料,需要的朋友可以參考下2023-01-01
C++基于reactor的服務(wù)器百萬并發(fā)實(shí)現(xiàn)與講解
這篇文章主要介紹了C++基于reactor的服務(wù)器百萬并發(fā)實(shí)現(xiàn)與講解,本文通過實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
C語言實(shí)現(xiàn)簡單通訊錄管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡單通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07

