我试图让A班成为B班的朋友。
class B;
class A{
public:
void show(const B&); // ##1## but this one works fine
B ob;// error incomplete type
};
class B{
public:
int b;
B():b(1){}
friend class A;
};
所以我的问题为什么它的类型不完整?我认为当我class B
时,它就像一个告诉编译的函数原型,在代码的某处有一个定义。
也在上面的代码## 1 ##为什么这可能?
答案 0 :(得分:9)
不,这是一个前向声明,并没有定义完整类型。如果您希望将成员保留为对象而不是指针,则需要在B
之前获得A
的完整定义。
其中一个原因是,B
必须知道班级A
的大小,因为A
的大小取决于B
我建议您#include "B.h"
中A.h
。
编辑:澄清:
struct A;
struct B
{
A foo();
void foo(A);
void foo(A&);
void foo(A*);
A* _a;
A& __a;
A a; // <--- only error here
};