问题起因:在完成Essencial C++第五章课后题时,定义了一个模板类同时时接口类,然后定义了一个子类去继承这个模板类,然后子类的实现在单独的cpp文件中进行,编译的时候报错LNK2019 无法解析的外部符号 "public: void __thiscall XXX,遂百度之,大多数说法都是,找不到lib,或者是只找到了方法的声明,没找到实现,我想这也不可能啊,我右键方法,然后找到声明都找得到,问啥会出这个问题呢?后来发现是关注点错了,这个问题的原因是涉及到了模板类的声明与定义
然后百度了关于C++模板类的相关问题,果然是一个问题牵出了其他的好多问题,对于这个问题的说明,这里直接转载两位大佬的博客,说的很详细
1.细谈 C++ 类模板的分离式编译https://blog.csdn.net/u012814856/article/details/84645963
2.模板类型声明和定义https://www.cnblogs.com/wonderKK/archive/2011/11/07/2240370.html
总结一下就是:在编译的时候,不会为模板类生成二进制代码,这时模板类只是一具躯壳,么得灵魂(因为如果要开辟空间的话,连具体的类型都不知道,如何去开辟空间呢),只有当发生了调用时,编译器才会给模板类去注入灵魂(即提供具体的类型),开辟空间。那么为什么必须把声明和定义写进 .h 的头文件当中呢,因为我们将其写到一起之后,会在头文件中同时找到模板类具现化所需的全部信息,因为他们都在一个文件中。但如果我们把声明和定义分别放在h和cpp文件中,但是我们的main函数所在的源文件中仅仅包含了模板类的声明,在编译的时候没有发现模板类具现化所需要的内容,于是认为该部分在其他文件中实现,将该任务交给链接器,但是链接器并没有找到模板类具现化的内容,因为我们在定义模板类的时候,使用的是 template<typename elemType>,并不是int 或者 float等具体类型,所以编译器也找不到会报错说无法定义的外部符号。