我试图让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;
};
所以我的问题为什么它是不完整的类型?我认为当我做B类时,它就像一个函数原型,它告诉编译器代码中有一个定义.
也可以在上面的代码## 1 ##为什么这是可能的?
解决方法:
不,这是一个前向声明,并没有定义完整类型.如果要将成员保留为对象而不是指针,则需要在A之前具有B的完整定义.
其中一个原因是B类的大小必须为A所知,因为A的大小取决于B.
我建议你在A.h.中#include“B.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
};