模板函数小结

一、用法举例

举个例子说明。

cpp 复制代码
#include <iostream>
using namespace std;

template <class T>//class也可以替换为typename
T Max(T a, T b)
{
	return a > b? a : b;
}

int main()
{
	//隐式调用
    cout << Max(1, 2) << endl;
    cout << Max("d", "b") << endl;
	//显式调用
	cout << Max<double>(1.1, 2.2) << endl;
	
    return 0;
}

输出结果是:

cpp 复制代码
2
d
2.2

注意2点:

①template 和template 是同义的。

②cout << Max(1.1, 2.2) << endl;是显式调用的写法。

二、声明和定义

在工程中,模板函数通常需要在头文件中同时声明和定义。原因是,模板函数在被调用时需要进行实例化(即把模板类替换成实际类),将模板函数的定义放在头文件中可以确保在每个使用该模板函数的源文件中都能够进行实例化并生成相应的代码。

如果将模板函数的定义移到源文件中,编译器在编译其他源文件时将无法看到完整的定义,导致无法进行实例化和生成代码,从而导致链接错误。因此,通常情况下,模板函数的定义应该与声明放在同一个头文件中。

如果非要将模板函数的定义移到源文件中,可以。下面是一个用C++代码的示例:

头文件 template_example.h:

cpp 复制代码
#ifndef TEMPLATE_EXAMPLE_H
#define TEMPLATE_EXAMPLE_H

template <typename T>
void templateFunction(T value);

#endif  // TEMPLATE_EXAMPLE_H

源文件 template_example.cpp:

cpp 复制代码
#include "template_example.h"
#include <iostream>

template <typename T>
void templateFunction(T value) {
    std::cout << "Template function called with value: " << value << std::endl;
}

// 显式实例化模板函数
template void templateFunction<int>(int);  // 实例化模板函数用于 int 类型
template void templateFunction<double>(double);  // 实例化模板函数用于 double 类型

// 更多的实例化语句可以根据需要添加

主文件 main.cpp:

cpp 复制代码
#include "template_example.h"

int main() {
    templateFunction(42);  // 调用针对 int 类型的模板函数
    templateFunction(3.14);  // 调用针对 double 类型的模板函数

    return 0;
}

在这个示例中,模板函数 templateFunction 的声明被放在头文件 template_example.h 中,并在源文件 template_example.cpp 中进行定义。在 template_example.cpp 中,通过显式实例化模板函数 templateFunction,分别为 int 和 double 类型提供了具体的模板参数。这样可以确保在编译时会生成对应的模板函数定义。在主文件 main.cpp 中,通过包含头文件 "template_example.h",可以在需要的地方调用模板函数。

需要注意的是,为了确保模板函数的实例化,源文件 template_example.cpp 需要被编译并链接到主文件中,以生成可执行程序。可以采取如下2种方法确保源文件 template_example.cpp 被编译并链接到主文件中:

①在构建系统中添加源文件:在构建系统(如CMake、Makefile等)中将 template_example.cpp 添加到源文件列表中,以便在编译时将其编译为目标文件,并与 main.cpp 进行链接。这样,在构建项目时,构建系统会自动处理源文件的编译和链接过程。

②在主文件中包含源文件:在 main.cpp 文件中加一行:

cpp 复制代码
#include  "template_example.cpp"

这样,编译器在编译 main.cpp 时会将两个文件的内容一起处理,从而将模板函数的定义包含在主文件中。这种方法适用于规模较小的项目,但在大型项目中可能会导致编译时间增加和代码结构混乱,因此不太常见。

相关推荐
weixin_307779131 小时前
Jenkins Metrics 插件全解析:从数据采集到智能监控的实践指南
运维·开发语言·架构·jenkins
阿拉伯柠檬1 小时前
实现一个异步操作线程池
开发语言·数据结构·c++·面试
半瓶榴莲奶^_^1 小时前
后端Web进阶(AOP)
java·开发语言
raoxiaoya1 小时前
ADK-Go:Golang开发AI Agent
开发语言·人工智能·golang
一只乔哇噻1 小时前
java后端工程师+AI大模型开发进修ing(研一版‖day61)
java·开发语言·学习·算法·语言模型
2301_803554521 小时前
Qt禁止子线程直接操作GUI
c++
我爱学习_zwj1 小时前
Node.js模块管理:CommonJS vs ESModules
开发语言·前端·javascript
ldmd2841 小时前
Go语言实战:入门篇-6:锁、测试、反射和低级编程
开发语言·后端·golang
Cx330❀1 小时前
Git 基础操作通关指南:版本回退、撤销修改与文件删除深度解析
大数据·运维·服务器·git·算法·搜索引擎·面试
前端小白在前进1 小时前
力扣刷题:合并两个有序数组
算法·leetcode·职场和发展