7

如何在 C++ 中实现相互递归的类?就像是:

/*
 * Recursion.h
 *
 */

#ifndef RECURSION_H_
#define RECURSION_H_

class Class1
{
  Class2* Class2_ptr;
public:
  void Class1_method()
  {
      //...
      (*Class2_ptr).Class2_method();
      //...
  }
};

class Class2
{
    Class1* Class1_ptr;
public:
    void Class2_method()
    {
        //...
        (*Class1_ptr).Class1_method();
        //...
    };
};


#endif /* RECURSION_H_ */
4

4 回答 4

7
  1. 前向声明类(你可以只前向声明其中一个,但为了更好的形式,两者都做)。
  2. 前向声明方法(同上)。
class Class1;
class Class2;

class Class1
{
  Class2* Class2_ptr;
public:
  void Class1_method();
};

class Class2
{
  Class1* Class1_ptr;
public:
  void Class2_method();
};

void Class1::Class1_method()
{
  //...
  (*Class2_ptr).Class2_method();
  //...
}

void Class2::Class2_method()
{
  //...
  (*Class1_ptr).Class1_method();
  //...
}
于 2010-08-04T23:42:10.297 回答
4

使用前向声明。

class Class2;

class Class1
{
  Class2* Class2_ptr;
};

class Class2 
{
  Class1* Class1_ptr;
}

因为 Class1 中的方法将取决于 Class2 的实际定义,所以方法定义必须出现在 Class2 声明之后,因为您不能仅使用前向声明中的方法。

另一方面,这种紧密耦合通常表明设计不佳。

于 2010-08-04T23:30:36.023 回答
1

预先声明其中一个类,例如Class2

#ifndef RECURSION_H_
#define RECURSION_H_
class Class2;
class Class1
{
   Class2* Class2_ptr;
   public:
   void Class1_method()
   {
      //...
      (*Class2_ptr).Class2_method();
      //...
   }
};

class Class2
{
     // ...
}  
于 2010-08-04T23:31:16.827 回答
1

前向声明顶部的类之一(或两者),例如:

class Class2;
class Class1 { ... };

并在定义两个类之后定义方法(即离线):

class Class1
{
 ...
 void Class1_method(); // just declare
 ...
};

class Class2
{
 ...
};

// once definition of Class2 is known, we can define the method of Class1
void Class1::Class1_method()
{
      //...
      (*Class2_ptr).Class2_method();
      //...
}
于 2010-08-04T23:31:49.853 回答