一:基本概念及基本范例
#include <iostream>
#include <vector>
using namespace std;
#pragma warning(disable : 4996)
//别名模板
template<typename T>
using myvect = std::vector<T, allocator<T>>;
template <
typename T,
template <class> class coniter //coniter相当于myvect
>
class myv
{
public:
coniter<T> m_vec;
};
int main()
{
//模板模板参数
//英文名:Template Template Parameters。就是:让模板参数本身成为模板。
//如果要在模板当中使用容器,可以在模板参数当中使用模板模板参数。
//a)类型模板参数,b)非类型模板参数,c)模板模板参数。
myv<int, myvect> obj;
return 0;
}
二:语法补充
#include <iostream>
#include <vector>
#include <list>
#include <boost/type_index.hpp>
using namespace std;
#pragma warning(disable : 4996)
//template<typename T>
//using myvect = std::vector<T, allocator<T>>;
template <
typename T,
template <class> class coniter
//template <class> class coniter = std::vector 给默认值
//template <typename U> class coniter = std::vector 带U也是可以的,不过一般用不到,就省略了
>
class myv
{
public:
//coniter<T> m_vec;
};
int main()
{
//myv<int, vector> obj; cpp17开始支持这种语法,不需要和myvect一块配套使用了
return 0;
}
三:函数模板使用模板模板参数
#include <iostream>
#include <vector>
#include <list>
#include <boost/type_index.hpp>
using namespace std;
#pragma warning(disable : 4996)
template<typename T>
using myvect = std::vector<T, allocator<T>>;
template <typename T,
template<class> class continer
>
void fun()
{
continer<T> obj;
obj.push_back(1);
cout << obj[0] << endl;
}
int main()
{
fun<int, myvect>();
return 0;
}