如何解决标头中声明的非模板函数用于模板函数,导致/ bin / ld:DWARF错误:找不到变量规范
也感谢您抽出宝贵时间来研究这个问题。我已经搜索了这个问题的答案,但是当您不知道确切要搜索什么时,很难找到答案。
我想在同一文件中声明的模板函数中使用头文件中声明的函数。我有两个文件,一个标头和一个源文件。非模板功能在cpp文件中定义。尽管出于某种原因,这会导致这种情况。这是导致问题的功能的简化示例。请让我知道是否需要更多信息,并感谢您提前获得的任何见识。
请注意,将代码从func.cpp
中定义的函数拖放到模板函数中即可直接进行编译和运行。这样做的问题是,如果我无法定义要在模板函数中使用的其他函数,我的函数将达到的长度。我要避免这种情况。
func.h:
void getDerivative(std::map<std::string,double> comp,double* omega,std::map<std::string,size_t> indexMap);
template<class MATTYPE> void Precondition(Matrix<MATTYPE> *preconditioner)
{
double* omega = new double[numberOfEquations];
std::map<std::string,double> comp = getComp(); //Included function to get comp
getOmega(omega); //Included function to get omega
std::map<std::string,size_t> indexMap = getIndexMap(); //Included function to get index map
getDerivative(comp,omega,indexMap);
.
.
}
func.cpp
void getDerivative(std::map<std::string,size_t> indexMap)
{
//flattened index for derivatives
size_t idx;
for (std::map<std::string,double>::iterator iter1 = comp.begin(); iter1 != comp.end(); iter1++) //Independent variable
{
for (std::map<std::string,double>::iterator iter2 = comp.begin(); iter2 != comp.end(); iter2++) //Dependent variable
{
idx = indexMap[iter1->first]+indexMap[iter2->first]*indexMap.size();
std::cout<<idx<<std::endl;
}
}
}
错误
/bin/ld: /bin/ld: DWARF error: could not find variable specification at offset 2045
/bin/ld: DWARF error: could not find variable specification at offset 209e
.
.
.
undefined reference to getDerivative(std::map<std::__cxx11::basic_string<char,std::char_traits<char>,std::allocator<char> >,double,std::less<std::__cxx11::basic_string<char,std::allocator<char> > >,std::allocator<std::pair<std::__cxx11::basic_string<char,std::allocator<char> > const,double> > >,double*,std::map<std::__cxx11::basic_string<char,unsigned long,unsigned long> > >)
collect2: error: ld returned 1 exit status
scons: *** [dev-test] Error 1
scons: building terminated because of errors.
更新:
我发现了一件有趣的工作,我不能完全确定它是如何工作的,但是如果我用{p>包裹getDerivative
的声明和定义,
extern C
{
}
然后代码编译并运行。
第二次更新:
我发现,如果我也将定义移到头文件中,并附加inline
,代码也将编译并运行。对于我的意图来说,这是一个合适的解决方法,但我仍然很想知道为什么第一种情况不起作用。
谢谢!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。