C++实现模板类头文件和实现文件分离的方法

最近在学习类模板,按照书上说的代码敲了,发现运行不了,去查了之后发现可以这样解决:
参考文章:参考文章
在测试文件中(含有main函数的文件)中将 模板类的实现文件包含进来,即将 .cpp 文件包含进来,而不是将 .h 文件包含进来。
具体案例如下:(在vs2017上编译通过,可以运行)
Store.h 文件:

#pragma once
#include <iostream>
using namespace std;

template <class T>
class Store
{
   
public:
	Store();
	T &getElem();		//提取数据函数
	void 
  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当我们需要将模板类的定义和实现分离到不同的文件中时,可以将模板类的声明放在一个文件中,将模板类的实现放在一个cpp文件中。 假设我们有一个模板类`MyClass`的声明: ```c++ // MyClass.h #pragma once template<typename T> class MyClass { public: MyClass(T value); void printValue(); private: T m_value; }; ``` 在模板类的定义中,我们只需要声明构造函数和`printValue`函数的方法,而不需要提供函数的具体实现,因为这些实现将在另一个文件中提供。 现在我们需要在一个cpp文件中提供模板类的实现: ```c++ // MyClass.cpp #include "MyClass.h" #include <iostream> template<typename T> MyClass<T>::MyClass(T value) : m_value(value) {} template<typename T> void MyClass<T>::printValue() { std::cout << "Value: " << m_value << std::endl; } // 显式实例化模板类 template class MyClass<int>; template class MyClass<float>; ``` 在这个文件中,我们提供了模板类的实现,包括构造函数和`printValue`函数的具体代码。此外,我们还需要显式实例化模板类,这将在编译时生成模板类的实例化代码。在这个例子中,我们实例化了`MyClass<int>`和`MyClass<float>`两个类型的模板类。 最后,在需要使用模板类的文件中,只需要包含文件即可: ```c++ // main.cpp #include "MyClass.h" int main() { MyClass<int> obj(42); obj.printValue(); return 0; } ``` 在这个例子中,我们实例化了一个`MyClass<int>`类型的对象,并调用了它的`printValue`函数。编译器将在编译时生成实例化的代码,并将其链接到最终的可执行文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值