4

我试图让 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##上面的代码中,为什么这是可能的?

4

1 回答 1

10

不,这是一个前向声明,并没有定义完整的类型。如果要将成员保留为对象而不是指针,则需要对Bbefore进行完整定义。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
};
于 2012-05-04T09:49:55.860 回答