【问题标题】:Undefined symbols for architecture x86_64, shared Util Library, build with cmake,架构 x86_64 的未定义符号,共享 Util 库,使用 cmake 构建,
【发布时间】:2013-11-26 23:49:41
【问题描述】:

我有一个简单但令人困惑的问题。我搜索了堆栈溢出和网络,但没有找到任何有用的东西。我知道这个问题很常见,在堆栈溢出时也有人问过类似的问题,但它们并没有帮助我解决这个问题;

我正在构建一个在 C++ 中使用 ITK 和 VTK 的应用程序。它是使用 cmake 和 unix make 构建的,我使用的是 OS X 10.8.4 并使用 g++-4.2 进行编译。我有一个看起来像这样的结构:

    src
├── VascSeg //contains ITK filters that I have written
├── lib //contains header/source for some utility functions that I commonly use
└── test //contains tests for VascSeg Library

这是我得到的错误:

Undefined symbols for architecture x86_64:
  "void MyUt::print_vector<float>(std::vector<float, std::allocator<float> >&, char const*)", referenced from:
      _main in VascularLevelSetTest.cxx.o

  "void MyUt::DeepCopy<itk::Image<float, 2u> >(itk::Image<float, 2u> const*, itk::Image<float, 2u>::Pointer)", referenced from:          itk::CommandLevelSetObserver<...>in VascularLevelSetTest.cxx.o
      itk::CommandLevelSetObserver<...>:
:SaveWriteImage(...)in VascularLevelSetTest.cxx.o
ld: symbol(s) not found for architecture x86_64

通常,这是包含不正确或不正确链接的错误。但是,我在这些文件中使用了许多其他函数,它们工作正常......我最近还更改了文件的结构,以使用带有源 (.cxx) 结构的 header(.h)。以前,我将声明和实现放在一个 .h 文件中。该文件太长且杂乱无章,因此我重构了标题/源结构。

相关线路:

using namespace MyUt;
...
std::vector<std::vector<float> > paramList_p1
std::vector<float> params1 = paramList_p1[config];
...

print_vector <float> (params1,"\t");

MyUtils.h:

namespace MyUt{
...
template<class T>
void print_vector(std::vector<T> &vec,const char* end = "\t");
...
}

MyUtils.cxx:

namespace MyUt{
...
template<class T>
void print_vector(std::vector<T> &vec,const char* end = "\t")
{...}
...
}

lib/CMakeLists.txt:

add_library(MyUtils SHARED MyUtils.cxx 
            vtkUtils.cxx)
SET_TARGET_PROPERTIES(MyUtils PROPERTIES LINKER_LANGUAGE CXX)
target_link_libraries(MyUtils ${ITK_LIBRARIES} ${VTK_LIBRARIES})

测试/CMakeLists.txt:

add_executable(VST VascularLevelSetTest.cxx)
TARGET_LINK_LIBRARIES(VST MyUtils)
TARGET_LINK_LIBRARIES(VST ${ITK_LIBRARIES})

如果这是一个重复的问题,我很抱歉,但我发现的所有问题都没有帮助我。

编辑:

我省略了 DeepCopy 错误的行,但我认为这些问题可能是相关的。所以我把它省略了,以使我的帖子更简洁。

【问题讨论】:

标签: c++ linker makefile cmake


【解决方案1】:

您的问题是:模板函数(此处为print_vector必须显式实例化,或者其定义(主体)必须中可用每个使用它的翻译单元。

通常这意味着您永远不能将模板函数定义放入.cxx 文件中(就像您在此处所做的那样)并期望它能够工作。

它可能与一个版本的编译器一起工作,只是在下一个版本中中断,或者它可能根本不工作。

TL;DR 将print_vector 的正文从MyUtils.cxx 移动到MyUtils.h

【讨论】:

  • 我明白了。谢谢您的回答!我现在从我的本科班上记得这一点......我已经看到模板类放入单独的文件并包含在 .h 文件的底部。有没有很好的指导方针?
猜你喜欢
  • 2016-07-29
  • 2015-10-11
  • 2017-05-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-03-09
  • 2015-03-22
  • 1970-01-01
相关资源
最近更新 更多