相互引用的两个类

Posted

技术标签:

【中文标题】相互引用的两个类【英文标题】:two classes referencing each other 【发布时间】:2013-05-25 21:06:57 【问题描述】:

假设有两个类,它们相互需要:containeritemcontainer 类创建了item 类的实例。 item 类的每个实例都持有一个container 类的实例,只需要调用container 类的method_call_by_item 方法即可. container 类需要查看 item 类的所有字段。

问题是前向声明:我想在 item.h 内部有一个前向声明,以便类 item 可以有一个 container 作为字段并调用方法method_call_by_item。我该怎么做?

容器,创建项目。

// container.h
#ifndef CONTAINER_H
#define CONTAINER_H

#include "item.h"

class container

public:
  item * create_item();
  void method_called_by_item(item * i);
;

#endif //CONTAINER_H

实现:

// container.cpp
#include "container.h"

item * container::create_item()
  return new item(this);


void container::method_called_by_item(item * i)
  // do stuff with item

item,需要调用容器的一种方法:

// item.h
#ifndef ITEM_H
#define ITEM_H

#include <iostream>

class container;

class item

public:
  item(container * c);
  void do_something();
  container * c;
;

#endif //ITEM_H

实现:

// item.cpp
#include "item.h"

item::item(container * c)
  this->c = c;

void item::do_something()
  this->c->method_called_by_item(this);

【问题讨论】:

【参考方案1】:

在容器.h中

class item; // do not include the item.h

在容器.cpp中

#include "item.h"

在 item.h 中

class container; // do not include container.h

在 item.cpp 中

#include "container.h"

【讨论】:

【参考方案2】:

您已经将前向声明添加到 item.h,所以您只需将以下行添加到 item.cpp

#include "container.h"

container.h 已经包含 item.h 所以你没有做任何额外的改变,但Mahmoud Fayez指出您也可以在那里添加前向声明。这将消除通常需要的对头文件的依赖——它可以减少大型项目的构建时间,并允许头文件“独立存在”。

【讨论】:

现在,既然这些类相互引用,那么在使用 shared_ptr 时如何调用析构函数? @James 您需要手动中断循环引用或酌情使用std::weak_ptr 显然我尝试了weak_prt,发现没有-> 运算符,所以我无法访问任何成员函数。但我弄清楚发生了什么。我做了更多的研究,发现我实际上应该使用标准指针来传递函数并维护对父/子类的引用。一旦我这样做了,析构函数就开始被调用。 @James 没有-&gt; 运算符,原因是 good - 你不知道弱指针是否引用了有效对象。您需要调用lock 以获取指向weak_ptr 的对象引用的共享指针。在这里使用原始指针是一个糟糕的想法,它违背了使用智能指针表达和管理生命周期和所有权的目的。

以上是关于相互引用的两个类的主要内容,如果未能解决你的问题,请参考以下文章

两个相互引用的类

C++中两个类相互包含引用问题

Django模型:两个类之间的相互引用以及在python中无法使用前向声明

两个类相互引用/从它的委托方法中的 UITextField 访问 UITableViewCell?

C++:两个相互引用的类

如何让两个模型相互引用 Django