C++ 模板

模版收尾

模版的声明和定义不能分离,否则会报错.

写下面三个文件:

cpp 复制代码
Stack.h

#pragma once
#include<iostream>
using namespace std;
template <class T>
T Add(const T& left, const T& right);
cpp 复制代码
Stack.cpp

#include"Stack.h"
template <class T>
T Add(const T& left, const T& right)
{
	cout << 1 << endl;
	return left + right;

}
cpp 复制代码
Test.cpp



#include"Stack.h"
int main()
{
	Add(1,2);
	fun();
	return 0;
}

运行结果:

如上图所示,模版的声明和定义分离会出现链接错误。

如果我们正常函数的定义和分离就不会出错,比如下图fun函数:

这是刚开始我们把代码加载进内存,运行之后先执行预处理,预处理把"Stack.h"展开。

展开之后就会在Stack.cpp里面找,但是Stack.cpp里面并没有对模版进行实例化,也就找不到地址:

为什么Add预处理阶段找不到地址呢?这是因为在Stack.cpp也就是定义里面Add没有被实例化:

Add是模版,没有实例化,在预编译阶段找不到地址,但是fun我们一开始就定义了是void类型,所以不管是预处理,编译,链接阶段都可以找到它的地址。

解决方案:

1.显示实例化:

缺点:换类型之后还要重新显示实例化,假设我此时这样写:

cpp 复制代码
Add(1.0, 2.0);

就会报错:

cpp 复制代码
1>Test.obj : error LNK2019: 无法解析的外部符号 "double __cdecl Add<double>(double const &,double const &)" (??$Add@N@@YANABN0@Z),函数 _main 中引用了该符号

需要再加个类型显示实例化:

cpp 复制代码
template
double Add<double>(const double& left, const double& right);

运行:

cpp 复制代码
1
1

但是这样太麻烦了,干脆不要声明定义分离了,把Stack.cpp删掉,定义全部放到Stack.h里面:

相关推荐
wangjialelele23 分钟前
Linux SystemV 消息队列 + 责任链模式:实现客户端消息处理流水线
linux·服务器·c语言·网络·c++·责任链模式
智者知已应修善业1 小时前
51单片机4按键控制共阳LED霓虹灯切换1整体闪烁2流水下3流水上4间隔闪烁】2023-10-27
c++·经验分享·笔记·算法·51单片机
洛水水1 小时前
结构性设计模式详解
c++·设计模式
曦夜日长1 小时前
C++ STL容器string(二):删除与插入、数据查找、自定义输入
java·开发语言·c++
fpcc2 小时前
跟我学C++中级篇—虚函数的优化
c++
智者知已应修善业2 小时前
【51单片机独立按键控制数码管自增自减】2023-10-5
c++·经验分享·笔记·算法·51单片机
ComputerInBook2 小时前
C++中“概念”(concept)之含义
开发语言·c++·概念·concept
程序员老舅2 小时前
Linux:谁把根目录卸载了?
linux·c++·容器·linux内核·文件系统·根目录
石山代码2 小时前
c++类型判断
开发语言·c++
雪度娃娃3 小时前
结构型设计模式——代理模式
java·c++·设计模式·系统安全·代理模式