我收到链接器错误:
duplicate symbol __ZN5ENDF64FileILNS_7MF_enumE1EE4readEv in:
Read.cpp.o
Material.cpp.o
Run Code Online (Sandbox Code Playgroud)
其中重复的符号名称是:
$ c++filt __ZN5ENDF64FileILNS_7MF_enumE1EE4readEv
ENDF6::File<(ENDF6::MF_enum)1>::read()
Run Code Online (Sandbox Code Playgroud)
我知道我不能在多个地方定义相同的功能 - 这是导致此链接器错误的原因.(我已经看到了这个问题:ld:复制符号)我不认为我read()在多个地方定义了函数,但是链接器(clang++)说我做了.
我在哪里复制read()符号?
我的代码结构如下所示:
//MFs.hpp
#ifndef MFS_HPP
#define MFS_HPP
enum class MF_enum {
...
}
#endif
//File.hpp
#ifndef FILE_HPP
#define FILE_HPP
#include "MFs.hpp"
// Definition of class File
template<>
class File {
...
}
// Definition of File<...>::read() function
template <>
void File<1>::read()
{
std::cout << "Reading into MF=1"<< std::endl;
}
#endif
Run Code Online (Sandbox Code Playgroud)
没有,File.cpp因为File课程是模板化的.所有定义(和声明)都在File.hpp
// Material.cpp
#include "File.hpp"
...
// Material.hpp
#ifndef MATERIAL_HPP
#define MATERIAL_HPP
#include "File.hpp"
...
#endif
Run Code Online (Sandbox Code Playgroud)
最后是驱动代码:
// Read.cpp
#include "Material.hpp"
#include "File.hpp"
int main (){
...
}
Run Code Online (Sandbox Code Playgroud)
(完成)模板的特化不是模板本身.如果您正在专门使用该函数,那么您需要在标题中声明它并在单个转换单元中提供实现,或者使内联定义:
// Header [1]
template <int>
class File {
// ...
void open();
};
template <>
void File<1>::open(); // just declaration
// Single .cpp
template <>
void File<1>::open() { ... }
Run Code Online (Sandbox Code Playgroud)
或者:
// Header [2]
template <int>
class File {
// ...
void open();
};
template <>
inline void File<1>::open() { ... }
Run Code Online (Sandbox Code Playgroud)