不是只能放在.h里面,但是推荐放在.h里面.STL模板实现全部是放在.h里面的.------------------编译能通过.1)参与编译的只是.cpp文件,不会报错的原因,是因为它能在.h里面找到模板的声明.链接错误.1)链接的时候,需要实例化模板,这时候就需要找模板的具体实现了.假设在main函数中调用了一个模板函数,这时候就需要去实例化该类型的模板.注意main函数里面只包含了.h文件,也就是只有模板的声明,没有具体实现.就会报错.2)而模板的实现.cpp里面,虽然有模板的具体实现,但是…
将模板的声明与定义写在一起实在很不优雅.尝试用“传统”方法,及在.h文件里声明,在.cpp文件里定义, 然后在main函数里包含.h头文件,这样会报链接错误.why!!!!!!!!!!!!! 这是因为函数模板要被实例化后才能成为真正的函数,在使用函数模板的源文件中包含函数模板的头文件,(carefully!!!) 如果该头文件中只有声明,没有定义,那编译器无法实例化该模板,最终导致链接错误.(类模板同样!!) //---------------test.h-------------------/…
c++模板类成员的声明和定义应该都放在*.h中,有普通类不一样. 如果定义放在*.cpp中,最终链接时,会报方法undefined错误. 参考:http://users.cis.fiu.edu/~weiss/Deltoid/vcstl/templates 如果非要定义在*.cpp中,一定要具体化模板类型,如下,但这样意味着你要定义无数个. 所以还是放在*.h中吧,用到的地方,编译器会帮你定义具体类型的方法. // error template<typename T> A<T>::f…
http://bbs.csdn.net/topics/380250382 adlay adlay 等级: #9 得分:0 回复于: 2012-03-31 11:19:35 引用 6 楼  的回复: 引用 4 楼  的回复: 通过显示实例化你可以把模版的实现放在 cpp 里, 要不然的话模版实现必须放在 .h 里面. 好像不显示实例化, 我把模板放在main.cpp里面也没报错啊, 比如你把刚才我那句注释掉, 也可以运行的. 你是只有一个 cpp 的情况. 如果有多个 cpp 文件再使用这个模版,…
1. 一个类: 头文件用于保存类的声明:定义文件保存类的实现.   2. 分离编译模式: 允许在一个编译单元(.cpp文件)中定义函数.类型.类对象等,然后在另一个编译单元中引用它们.编译器处理完所有的编译单元后,链接器接下来会处理所有指向extern符号的引用(有时为缺省),从而生成单一可执行文件.   3. 模板类型: 模板类型不是一种实类型,它必须等到类型绑定后才能确定最终类型,所以在实例化一个模板时,必须要能够让编译器“看到”在哪里使用了模板,而且必须看到模板确切的定义,而不仅仅是它们的…
新建一个class C;生成2个文件C.h和C.cpp,在C.h中声明一个函数 template<class T> T stringTo(char* str); 直接用VAssistX的Refactor-Create Implementation菜单,发现没有在C.cpp实现stringTo函数,而是在C.h中生成 template<class T> T C<T>::stringTo(char* str) { } 网上说template修饰的函数,目前的编译器对于分开声…
以下是我的代码: //TaskConfigFile.h #pragma once using namespace System::Collections::Generic; using namespace System; using namespace System::IO; using namespace System::Text; ref class TaskConfigFile { public: TaskConfigFile(); TaskConfigFile(String^ str_l…
编译器在编译模板时,并不会生成代码,只有遇到实例化的时候才会生成代码.因此,当我们只引用模板声明文件的时候,在实例化的对象时候,模板的定义问文件是不可见的,于是出现链接错误.例如: //A.h #pragma once template<typename T> class A{ public: A(); ~A(); }; //A.cpp #include"A.h" template<typename T> A<T>::A(){ } template&…
最近在仿写stl,发现stl源码中将模板的声明与定义写在一起实在很不优雅.自己尝试用“传统”方法,及在.h文件里声明,在.cpp文件里定义,然后在main函数里包含.h头文件,这样会报链接错误.这是因为函数模板要被实例化后才能成为真正的函数,在使用函数模板的源文件中包含函数模板的头文件,如果该头文件中只有声明,没有定义,那编译器无法实例化该模板,最终导致链接错误. 上面这句话有点抽象.要理解为什么会出错,首先要理解用传统方法写非模板函数时,编译器是怎么运作的.举个例子 //-----------…
这篇文章主要介绍了C++函数模板与类模板,需要的朋友可以参考下   本文针对C++函数模板与类模板进行了较为详尽的实例解析,有助于帮助读者加深对C++函数模板与类模板的理解.具体内容如下: 泛型编程(Generic Programming)是一种编程范式,通过将类型参数化来实现在同一份代码上操作多种数据类型,泛型是一般化并可重复使用的意思.泛型编程最初诞生于C++中,目的是为了实现C++的STL(标准模板库). 模板(template)是泛型编程的基础,一个模板就是一个创建类或函数的蓝图或公式.…