一,类模板之包含编译模型
//Queue.h
#ifndef _QUEUE_H_
#define _QUEUE_H_
template <class Type>
class Queue
{
public:
Queue(size_t len = 0);
Queue(const Queue& que);
size_t size()const;
private:
size_t length;
};
include "Queue.cpp"
endif //_QUEUE_H_
//Queue.cpp
#ifndef _QUEUE_CPP_
#define _QUEUE_CPP_
</span>#include "Queue.h"
template <class Type>
size_t Queue<Type>::size() const
{
return length;
}
template <class Type>
Queue<Type>::Queue( const Queue& que )
{
length = que.size();
}
template <class Type>
Queue<Type>::Queue( size_t len /*= 0*/ )
{
length = 0;
}
#endif //_QUEUE_CPP_</span>
注意:在Queue.h文件中加了文件保护,之所以这么做,是因为Queue.h中包含了Queue.cpp,而Queue.cpp中又包含了Queue.h,会导致重复定义的。
当然,也可以不在Queue.cpp文件中加文件保护,方法有三种:
方法一,Queue.cpp不能添加在工程中,即从工程中移除。
方法二,那就是将类的定义和实现全部放在Queue.h文件中,省略Queue.cpp文件。
方法三,分开头文件和源文件,在main中包含源文件,即#include "Queue.cpp"
二、类模板之分别编译模型
仅仅修改Queue.cpp文件,如下:
EXPORT template <class Type>
class Queue;
</span>#include "Queue.h"
template <class Type>
size_t Queue<Type>::size() const
{
return length;
}
template <class Type>
Queue<Type>::Queue( const Queue& que )
{
length = que.size();
}
template <class Type>
Queue<Type>::Queue( size_t len /*= 0*/ )
{
length = 0;
}
在vs2008中报错,VS中的EXPORT关键字目前不支持分离编译。
故尽量使用包含编译模型。
函数模板同上。