模板模板参数

一:基本概念及基本范例

#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;
}

猜你喜欢

转载自blog.csdn.net/qq_38158479/article/details/121176946