c++头文件定义模板类,cpp文件实现函数功能
时间: 2024-03-02 09:50:37 浏览: 24
当我们需要将模板类的定义和实现分离到不同的文件中时,可以将模板类的声明放在一个头文件中,将模板类的实现放在一个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`函数。编译器将在编译时生成实例化的代码,并将其链接到最终的可执行文件中。