未解析的外部符号“public: __thiscall Vector<int> [..]".
unresolved external symbol "public: __thiscall Vector<int> [...]"
因此,我创建了一个基本的VC++程序,并使用1个方法(除了构造函数和析构函数)创建了一个模板类。我收到以下错误:
>main.obj : error LNK2019: unresolved external symbol "public: __thiscall Vector<int>::~Vector<int>(void)" (??1?$Vector@H@@QAE@XZ) referenced in function _main
>main.obj : error LNK2019: unresolved external symbol "public: __thiscall Vector<int>::Vector<int>(int)" (??0?$Vector@H@@QAE@H@Z) referenced in function _main
>c:usersedydocumentsvisual studio 2010Projectsex01Debugex01.exe : fatal error LNK1120: 2 unresolved externals
这是我的代码:
(CPP 类文件)
using namespace std;
#include "Vector.h"
template <class T> Vector<T>::Vector(int n)
{
this.crt = 0;
this.dim = n;
this.elem = new T[100];
}
template <class T> void Vector<T>::add(T e)
{
this.elem[crt] = e;
this.crt++;
}
template <class T> Vector<T>::~Vector(void)
{
this.crt = 0;
}
(H类文件)
#pragma once
template <class T> class Vector
{
public:
int dim;
T* elem;
Vector(int n);
void add(T e);
~Vector(void);
private:
int crt;
};
(主文件)
using namespace std;
#include "Vector.h"
int main(void)
{
Vector<int> x(5);
//x.add(1); <--- if i decomment this line, it throws an additional error
return 0;
}
大多数解决方案涉及未实现的方法,但我已实现所有方法。我不知道可能出了什么问题。有什么帮助吗?
模板类实现需要对所有使用它们的翻译单元可见。将实现移动到头文件。
在你问之前 - 不,没有办法隐藏它们,除非你事先知道你拥有的课程的哪些专业。如果希望Vector
是通用的,则实现需要可见。
如果要将它们分开,通常的方法是将实现放在一个.impl
文件中,并将其包含在标头中。
如果您打算在 .cpp
文件中实现模板,您还需要在其中提供模板的显式实例化。您可以添加到模板的.cpp
文件中:
class template Vector<int>;
在底部。这将实例化矢量模板的int
版本。但是,如果您遵循 Luchian 的建议,您会发现您的模板更容易使用。如果您按照他的建议进行操作,编译器将在您在不同类型的上使用Vector<>
时按需为您创建实例化。如果将其保留在.cpp
文件中,则每次要创建不同类型的Vector<>
时都必须添加显式实例化。
有些人认为显式实例化比隐式实例化"更精简",因为如果不同的对象文件集多次使用相同的模板实例化,编译器可能会创建同样多的实例化。但是,当可执行文件链接在一起时,链接器最终将删除重复的实例化。即便如此,如果多个共享库重复使用具有相同参数的同一模板,即使动态链接器会清理它,膨胀仍然存在。如果可执行加载时间很重要,这可能是首选显式实例化的原因。如果您有一个非常大的项目,并且生成和链接时间是一个问题,这也可能是首选显式实例化的原因。
否则,您应该坚持使用隐式实例化。
- 为什么在全局范围内使用"extern int a"似乎不行?
- int(c) 和 c-'0' 之间的区别。C++
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 是否可以从int转换为enum类类型
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 'short int'持有的值溢出,但"自动"不会溢出?
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 调用'begin(int [n])'没有匹配函数
- 没有显式声明的int[]中的foreach
- 在c++中访问int到类对象的映射时出错
- 为什么我无法更改"set<set>"循环中的值<int>
- 长 长 int 不要 长 int 好
- C++程序在循环后给出奇怪的int值
- 如何计算数据类型的范围,例如int
- 如果"new int"返回"int*",那么为什么"new int[n]"不返回"int**"?
- 如何在cpp.中使用协议缓冲区存储大缓冲区/数组(char/int)