c++ - Clang++ 使链接器在模板类上失败(但它适用于 g++)
问题描述
我有一个与 GCC 配合得很好的程序,但是用 Clang 编译它会使链接器失败。
我认为我的问题是模板类,所以我实现了这个小例子。
test.cpp
:
#include "Point.h"
int main()
{
Point<int> p1;
Point<int> p2{ 3, 6 };
}
Point.h
:
#ifndef POINT_H
#define POINT_H
template<typename T>
class Point {
T x, y;
public:
Point();
Point(T, T);
};
template class Point<int>;
template class Point<float>;
#endif
Point.cpp
:
#include "Point.h"
template<typename T>
Point<T>::Point()
: x{0}, y{0}
{}
template<typename T>
Point<T>::Point(T t_x, T t_y)
: x{t_x}, y{t_y}
{}
当我用 构建它时g++ Point.cpp test.cpp
,它可以正常工作。
但是对于 Clang,它会给出以下错误:
$ clang++ Point.cpp test.cpp
/usr/bin/ld: /tmp/test-8ab886.o: in function `main':
test.cpp:(.text+0x1a): undefined reference to `Point<int>::Point()'
/usr/bin/ld: test.cpp:(.text+0x2d): undefined reference to `Point<int>::Point(int, int)'
clang-11: error: linker command failed with exit code 1 (use -v to see invocation)
或者,使用 lld:
$ clang++ -fuse-ld=lld Point.cpp test.cpp
ld.lld: error: undefined symbol: Point<int>::Point()
>>> referenced by test.cpp
>>> /tmp/test-f95759.o:(main)
ld.lld: error: undefined symbol: Point<int>::Point(int, int)
>>> referenced by test.cpp
>>> /tmp/test-f95759.o:(main)
clang-11: error: linker command failed with exit code 1 (use -v to see invocation)
我想我的显式实例化Point.h
对于 Clang 来说还不够好,但我不知道它想要什么。
解决方案
您的显式实例化应该在定义可见的地方,所以在 Points.cpp 的末尾
从class_template#Explicit_instantiation:
显式实例化定义强制实例化它们所引用的类、结构或联合。它可能出现在模板定义之后的程序中的任何位置,并且对于给定的参数列表,只允许在整个程序中出现一次,不需要诊断。
推荐阅读
- mongodb - MongoDB / MongoId 中 HABTM 关系的限制是什么?
- powershell - 如何使用 powershell 设置为变量 csv 列?
- python - Pytorch:在训练时可视化模型
- r - R:如何根据其他四个变量的百分比创建一个新变量?
- python - 访问我自己的图像文件或将它们从 S3 加载到 phoneoxpth 到 sage maker
- java - 如何使工具栏留在屏幕上?
- php - 我怎样才能记住输入中的文本
- javascript - 来自 PHP Ajax 的 Fullcalendar 的 eventSources 选项值
- firebase - 如何从firebase(颤振)将数组数据返回到移动屏幕
- angular - 如何更新整个收藏?Firebase 数据库迁移