请教下在c++中将声明头文件和头文件函数实现分离,导致在调用中出现 undefined reference to 怎么解决

1.头文件

#include<iostream>

#include<string>

using namespace std;

class DemoTest

{

public:

   DemoTest();

   void show();

   ~DemoTest();

};

2.头文件函数实现cpp文件

using namespace std;

#include"DemoTest.h"

DemoTest::DemoTest()

{

   cout<<"Constructing"<<endl;

}

DemoTest::~DemoTest()

{

  cout<<"Deleting"<<endl;

}

void DemoTest::show()

{

    cout<<"Superising"<<endl;

}

3.测试文件

#include<iostream>

#include"DemoTest.h"

using namespace std;

int main()

{

    DemoTest test;

    test.show();

}

4.错误

我将函数实现写到头文件内部是没有问题的,但是分开来实现就出现问题了,所以请教下c++大佬,这是什么原因,还是说不能这么实现。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
当我们需要将模板类的定义和实现分离到不同的文件时,可以将模板类的声明放在一个头文件,将模板类的实现放在一个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`函数编译器将在编译时生成实例化的代码,并将其链接到最终的可执行文件
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值