C++ 为什么模板只能在头文件中实现?
2016-04-26 20:02
281 查看
模板类的定义和实现必须要在同一个文件中,通常是头文件,编译器要看到模板实现才能展开模板。
因为初始化一个模板,编译器根据模板的参数创建一个新的类。比如:
template<typename T>struct Foo{
T bar;
void doSomething(T param) {/* do stuff using T /}};
// somewhere in a .cpp
Foo<int> f;
编译器在解析到这段代码时,会创建一个新类,等价于:
struct FooInt{
int bar;
void doSomething(int param) {/ do stuff using int */}}
当编译器需要访问方法实现时,用模板参数去实例化他们时,比如这个情况下是int。如果实现不在头文件,方法是访问不到的,那样编译器就不能实例化那个模板。常用的方法是,在头文件中声明模板,在一个模板文件中实现那些类。然后在头文件的尾部包含具体实现的文件。例如
// Foo.htemplate <typename T>struct Foo{
void doSomething(T param);};
#include "Foo.tpp"
// Foo.tpptemplate <typename T>void Foo<T>::doSomething(T param){
//implementation}
这样,实现和声明是分开的,编译器也能访问到。
因为初始化一个模板,编译器根据模板的参数创建一个新的类。比如:
template<typename T>struct Foo{
T bar;
void doSomething(T param) {/* do stuff using T /}};
// somewhere in a .cpp
Foo<int> f;
编译器在解析到这段代码时,会创建一个新类,等价于:
struct FooInt{
int bar;
void doSomething(int param) {/ do stuff using int */}}
当编译器需要访问方法实现时,用模板参数去实例化他们时,比如这个情况下是int。如果实现不在头文件,方法是访问不到的,那样编译器就不能实例化那个模板。常用的方法是,在头文件中声明模板,在一个模板文件中实现那些类。然后在头文件的尾部包含具体实现的文件。例如
// Foo.htemplate <typename T>struct Foo{
void doSomething(T param);};
#include "Foo.tpp"
// Foo.tpptemplate <typename T>void Foo<T>::doSomething(T param){
//implementation}
这样,实现和声明是分开的,编译器也能访问到。
相关文章推荐
- Word Search
- 《C++ Primer》习题
- 详解C++类的内存分布结构
- 第四次c++作业——输出星号图
- 使用QImage进行高质量绘制(High-Quality Rendering with QImage)
- C++学习笔记 - libevent浅尝
- c++作业-4
- C++第四次作业
- C++实验4
- C++初始化列表
- 学习笔记之深入浅出MFC 第8章 C++重要性质----基类与派生类:谈继承(Inheritance)
- 高级c++头文件bits/stdc++.h
- c++作业4
- VC++的Unicode编程
- 用C语言写的超长的大数乘法,不支持负数,新手上路请多指点
- 作业:C++作业4
- C++作业4
- C++实验4—输出星号图
- C++实验4-输出星号图
- C++报错集锦