原文链接:http://www.cnblogs.com/hanxi/archive/2012/07/25/2608068.html
前几天很不爽,因为C++中两个类中互相包含对方对象的指针编译时提示某一个类未定义。。。所以我就想啊想,这样也对,我的头文件都有#ifndef的,包含了一次就不能再包含了,以为就实现不了这样的功能,于是就改了设计方案:
class A
{
public:
A(B* pB):m_pB(pB)
{
} private:
B* m_pB;
}; class B
{
public:
B() {}
private:
int m_i;
};
只在一个类中包含另一个类的指针(算是聚类吧,A不管理m_pB的死活),而在B需要A的属性时通过传递参数进去。这样有些麻烦,但是勉强达到了我的需求。
今天,又遇到一个必须使用相互包含对象指针的问题,要不然通过参数传来传去麻烦的不得了。所以还是百度了下,结果终于找到了:(c++)两个类相互包含引用的问题。里面说的和我需要的差不多,解决方法是一样的。
文章里面说的很清楚了,我也在这里复述一遍吧,主要解决的就是文件包含的问题:在A的头文件(A.h)中包含B的头文件(B.h),在A的源文件(A.cpp)中包含(A.h),在B的头文件中使用A的声明(class A;)而不是包含A的头文件,然后在B的源文件(B.cpp)中包含A的头文件和B的头文件。代码如下:
// A.h
#include "B.h"
class A
{
public:
A(B* pB):m_pB(pB) {}
void useB();
private:
B* m_pB;
}; //A.cpp
#include "A.h"
void A::useB()
{
//do something for m_pB
} //B.h
class A;
class B
{
public:
B(A* pA):m_pA(pA) {}
void useA(); private:
A* m_pA;
}; //B.h
#include "A.h"
#include "B.h"
void B::useA()
{
//do something for m_pA
}
这样的话B的头文件中不能有使用A的对象指针m_pA的代码,否则会出现“使用了未定义的A”错误。
最后,问题算是解决了,但是我现在还是有点不明白的,这C++头文件的包含和类的声明等等都应该牵涉到编译器的编译顺序问题,忘大师为我讲解下这是为什么。
谢谢观众的捧场!
原文作者:涵曦(www.hanxi.info)
原文作者微博:t.qq.com/hanxi1203
出处:hanxi.cnblogs.com
原文作者GitHub:github.com/hanxi