-
25-09-2019 - |
题
如何在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_ */
解决方案
- 向前划分的课程(您可以逃脱前向练习中的一个,但同时可以做到这两个)。
- 向前销售方法(同上)。
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();
//...
}
其他提示
使用远期声明。
class Class2;
class Class1
{
Class2* Class2_ptr;
};
class Class2
{
Class1* Class1_ptr;
}
因为Class1中的方法将取决于Class2的实际定义,因此必须在Class2声明之后进行方法定义,因为您不能仅使用正向声明中的方法。
另一方面,这种紧密的耦合通常表明设计不良。
例如,其中的一个课程之一 Class2
#ifndef RECURSION_H_
#define RECURSION_H_
class Class2;
class Class1
{
Class2* Class2_ptr;
public:
void Class1_method()
{
//...
(*Class2_ptr).Class2_method();
//...
}
};
class Class2
{
// ...
}
向前声明顶部的一类(或两者),例如:
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();
//...
}
不隶属于 StackOverflow