次の2つのシナリオを検討してください(質問全体を完成させ、より明確にするために編集しました)
ケース 1: (以下に正しく記載されているようにコンパイルされない)
//B.h
#ifndef B_H
#define B_H
#include "B.h"
class A;
class B {
A obj;
public:
void printA_thruB();
};
#endif
//B.cpp
#include "B.h"
#include <iostream>
void B::printA_thruB(){
obj.printA();
}
//A.h;
#ifndef A_H
#define A_H
#include "A.h"
class A {
int a;
public:
A();
void printA();
};
#endif
//A.cpp
#include "A.h"
#include <iostream>
A::A(){
a=10;
}
void A::printA()
{
std::cout<<"A:"<<a<<std::endl;
}
//main.cpp
#include "B.h"
#include<iostream>
using namespace std;
int main()
{
B obj;
obj.printA_thruB();
}
ケース 2: (唯一の変更...コンパイル エラーなしで動作します)
//B.h
#include "A.h" //Add this line
//class A; //comment out this line
A.cpp と B.cpp の両方が一緒に準拠していると仮定します。上記の 2 つのシナリオに違いはありますか? ある方法を他の方法よりも優先する理由はありますか?
編集:では、シナリオ1を機能させるにはどうすればよいですか。