2013-11-28 74 views
-1

编写C++模板的时候,我有一个问题,让我们来检查代码:关于C++模板错误

abc.h 

class ABC 
{ 
public: 
     template <class T> 
     T getSomething(const std::string& name, ABC* owner = 0); 
     ABC* getSomething(const std::string& name); 
}; 

abc.cpp 


#include "abc.h" 

template <class T> 
T ABC::getSomething(const std::string& name, ABC* owner) 
{ 
     return dynamic_cast<T>(owner ? owner->getSomething(name) : getSomething(name)); 
} 


ABC* ABC::getSomething(const std::string& name) 
{ 
     return NULL; 
} 

,我的主要功能将是这样的:

int main() 
{ 
     ABC abc; 
     ABC* test = abc.getSomething<ABC*>("hello", NULL); 
} 

当我把我的主要在这个abc.cpp并编译它,没有问题一切正常

但问题出现在我使用这个abc.cpp(后来我编译成abc.o),然后把我的主函数在不同的文件(比如说,def.cpp)。

我真是奇怪的错误,该错误表示:

/tmp/ccn1H4Bg.o: In function `main': 
def.cpp:(.text+0x4a): undefined reference to `ABC* ABC::getSomething<ABC*>(std::basic_string<char, std::char_traits<char>, std::allocator<char> > const&, ABC*)' 
collect2: ld returned 1 exit status 

大家能帮助我什么,我错在这里做什么?

谢谢!

回答

2

这是因为编译器不支持单独的模板编译。将abc.cpp中的模板代码移至abc.h即可解决此问题。像这样:

//abc.h 
class ABC 
{ 
public: 
     template <class T> 
     T getSomething(const std::string& name, ABC* owner = 0); 
     ABC* getSomething(const std::string& name); 
}; 

template <class T> 
T ABC::getSomething(const std::string& name, ABC* owner) 
{ 
     return dynamic_cast<T>(owner ? owner->getSomething(name) : getSomething(name)); 
} 

//abc.cpp 
ABC* ABC::getSomething(const std::string& name) 
{ 
     return NULL; 
} 

//def.cpp 
int main() 
{ 
     ABC abc; 
     ABC* test = abc.getSomething<ABC*>("hello", NULL); 
}