C++中的模板(二)

cpp 复制代码
template<typename T1,typename T2>//这里的typename也可以替换成class
T1 Func(const T1& a,const T2& b){//也可以有返回值
cont<<a<<""<<b<<endl;
}
//实例化推演出具体的函数
int main(){

Func(x,y);
}
cpp 复制代码
template<typename T>
Add(const T& a,const T& b){/const 放置权限被放大
return a+b;
}

int main(){
//实参传递的类型,推演T 的类型
double x=1.2,y=2.3;
int s=1,z=9;
count<<Add((int)x,z)<<endl;
count<<Add(x,(double)z)<<endl;
//显式实例化
count<<<int>Add(a,z)<<endl;
count<<<double>Add(a,z)<<endl;
}
cpp 复制代码
template<ttypename T>
T* Alloc(int n)
{
    return new T[n];
}

int main(){
 // 有些函数无法自动推,只能显示实例化
   double* p1 = Alloc<double>(10);
return 0;
}

类模板

cpp 复制代码
// 类模板
template<class T>
class Stack
{
public:
	Stack(size_t capacity = 3);

	void Push(const T& data);

	// 其他方法...

	~Stack()
	{
		if (_array)
		{
			free(_array);
			_array = NULL;
			_capacity = 0;
			_size = 0;
		}
	}

private:
	T* _array;
	int _capacity;
	int _size;
};

int main()
{
	Stack<int> s1;    // int
	Stack<double> s2; // double
	Stack<char> s3;   // char

	return 0;
}


template<class T>
Stack<T>::Stack(size_t capacity)
{
	/*_array = (T*)malloc(sizeof(T) * capacity);
	if (NULL == _array)
	{
		perror("malloc申请空间失败!!!");
		return;
	}*/
	_array = new T[capacity];

	_capacity = capacity;
	_size = 0;
}

template<class T>
void Stack<T>::Push(const T& data)
{
	// CheckCapacity();
	_array[_size] = data;
	_size++;
}
template<class T>
void Stack<T>::Push(const T& data)
{
	// CheckCapacity();
	_array[_size] = data;
	_size++;
}

int main()
{
	Stack<int> s1;    // int
	Stack<double> s2; // double
	Stack<char> s3;   // char

	return 0;
}
复制代码

// 普通类,类名和类型是一样

// 类模板,类名和类型不一样

// 类名:Stack

// 类型:Stack<T>

相关推荐
i220818 Faiz Ul几秒前
动漫商城|基于springboot + vue动漫商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·动漫商城系统
白藏y9 分钟前
【C++】muduo接口补充
开发语言·c++·muduo
海兰15 分钟前
【实战】MCP 服务在 Nacos 中注册状态分析与优化
android·java·github·银行系统·银行ai
zk_one36 分钟前
【无标题】
开发语言·前端·javascript
阿里嘎多学长43 分钟前
2026-04-05 GitHub 热点项目精选
开发语言·程序员·github·代码托管
xiaoye-duck44 分钟前
《算法题讲解指南:递归,搜索与回溯算法--综合练习》--14.找出所有子集的异或总和再求和,15.全排列Ⅱ,16.电话号码的字母组合,17.括号生成
c++·算法·深度优先·回溯
OOJO44 分钟前
c++---vector介绍
c语言·开发语言·数据结构·c++·算法·vim·visual studio
Makoto_Kimur1 小时前
Java 打印模板大全
java·开发语言·排序算法
程序员榴莲1 小时前
Java(十)super关键字
java·开发语言
HAPPY酷1 小时前
Python高级架构师之路——从原理到实战
java·python·算法