尝试将父类对象传递给子类对象,以便子类对象可以控制父类对象的方法.
然而,这导致与标题相关的问题.我已经尝试过声明其中一个类,但似乎首先声明的类总是无法从下面声明的类中读取.
这两个错误都引用了Device的构造函数,试图调用dm的hello world方法,它们是:
Use of undefined type 'DeviceManager'
Left of '->HelloWorld' must point to class/struct/union/generic type
Run Code Online (Sandbox Code Playgroud)
...
//main.cpp
#include "parent.h"
void main()
{
cout << "Created DeviceManager\n";
DeviceManager* deviceManager = 0;
deviceManager = new DeviceManager;
cout << "Giving DeviceManager a device\n";
deviceManager->p = new Device(deviceManager);
cout << "Giving Device a reference to DevicenManager\n";
deviceManager->Share();
}
Run Code Online (Sandbox Code Playgroud)
...
class DeviceManager;
class Device
{
public:
Device(DeviceManager* manager)
{
dm = 0;
this->dm = manager;
this->dm->HelloWorld();
}
DeviceManager* dm;
};
//device manager
class DeviceManager
{
public:
DeviceManager()
{
p = 0;
}
void HelloWorld()
{
//if this calls we know the child has control over the parent.
cout << "Hello World";
}
Device* p;
};
Run Code Online (Sandbox Code Playgroud)
是.
要使用类成员和函数声明来解决循环依赖关系,您可以转发声明一个类:
class A;
class B {
A *a;
};
class A {
B *b;
};
Run Code Online (Sandbox Code Playgroud)
要定义访问另一个类的成员的类成员函数,必须在定义另一个类之后定义该函数:
class B;
class A {
public:
void f(B &arg);
};
class B {
public:
void g(A &arg);
};
void A::f(B &arg) {
arg.g(*this);
}
void B::g(A &arg) {
arg.f(*this);
}
Run Code Online (Sandbox Code Playgroud)
通常,在C++项目中,您甚至不会遇到此问题:您可以将函数定义(即实现)放入.cpp文件中,同时将类定义放入头文件中.如果需要,可以将类前向声明放入它们自己的头文件中,这些头文件包含在需要它们的所有头文件中.
如何将上述代码拆分为多个文件的完整示例:
a.cpp
#include "a.h"
#include "b.h"
void A::f(B &arg) {
arg.g(*this);
}
Run Code Online (Sandbox Code Playgroud)
b.cpp
#include "b.h"
#include "a.h"
void B::g(A &arg) {
arg.f(*this);
}
Run Code Online (Sandbox Code Playgroud)
啊
#ifndef _A_H_
#define _A_H_
#include "forward_declarations.h"
class A {
public:
void f(B &arg);
};
#endif //_A_H_
Run Code Online (Sandbox Code Playgroud)
BH
#ifndef _B_H_
#define _B_H_
#include "forward_declarations.h"
class B {
public:
void g(A &arg);
};
#endif //_B_H_
Run Code Online (Sandbox Code Playgroud)
forward_declarations.h
#ifndef _FORWARD_DECLARATIONS_H_
#define _FORWARD_DECLARATIONS_H_
class A;
class B;
#endif //_FORWARD_DECLARATIONS_H_
Run Code Online (Sandbox Code Playgroud)
作为一般的经验法则,如果你需要向前声明一个类,你可能会错误地设计一些东西并且应该考虑是否有更好的方法(但是也有完全有效的用例需要类前向声明).
如果你不理解我#ifndef,#define和#endif预处理线:这是头警卫,并应与使用所有被包括在其他地方的文件,除了你知道正是你在做什么.相信我.你会后悔忘记一个.