我是靠谱客的博主 乐观白昼,这篇文章主要介绍函数模板的重载,现在分享给大家,希望可以做个参考。

#include <iostream>
using namespace std;

template <typename T> T add(T a, T b)//定义一个函数模板add
{
	return a + b;
}

template <typename T> void add(T a[], T b[], T sum[],int n)//再定义一个函数模板add,参数不同,构成重载
{
	for (int i = 0; i < n; i++) 
	{
		sum[i] = a[i] + b[i];
	}
}

int main(void)
{
	float a = 10.0;
	float b = 10.1;
	float c = add(a, b);
	cout << c << endl;

	int A[5] = { 1,2,3,4,5 };
	int B[6] = { 1,2,3,4,5,6 };
	int sum[5];
	add(A, B, sum, 5);
	for (int i = 0; i < 5; i++)cout << sum[i]<<endl;
	return 0;
}
#include <iostream>
using namespace std;

template <typename T> T Max(T a, T b)
{
	return a > b ? a : b;
}

const char* Max(const char* a, const char* b)
{
	return strcmp(a, b) > 0 ? a : b;
}
int main(void)
{
	int a = 1;
	int b = 2;
	int c = Max(a, b);
	cout << c << endl;
	const char* p = "hello";
	const char* q = "world";
	const char* o = Max(p, q);
	//优先调用原型匹配函数const char* Max(const char* a, const char* b)
	//如果没找到匹配的函数,再查找模板生成的函数
	cout << o;
	return 0;
}

最后

以上就是乐观白昼最近收集整理的关于函数模板的重载的全部内容,更多相关函数模板内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(75)

评论列表共有 0 条评论

立即
投稿
返回
顶部