繁体   English   中英

C++ 设计(多继承 vs. 列出相关数据)

[英]c++ design (multiple inheritance vs. listing relevant data)

我有

class Skill
{
public :
  virtual void printSkill();
//....
}

class Person : public Skill
{


//...
}

在以前的设计中,每个人可以拥有一项技能,我可以打印出来

Person p;
p.printSkill();

现在我们要添加多个技能并显示它们。 我变了:

class Person
{
private:
vector<Skill*> m_skills;
pubcic:
void addSkill(Skill *s) { m_skills.push_back(s);}
void printSkills() const { 
  for auto it = m_skills.begin(); it != m_skills.end(); ++it)
  {
      it->printSkill();
  }
}
}
class Skill1 : public Skill
{
   void printSkill() ;
}

class Skill2 : public Skill
{
   void printSkill() ;
}

Person p;
Skill1 s1;
Skill2 s2;
p.addSkill(&s1);
p.addSkill(&s2);

这应该有效但我不喜欢这个。 也许我可以在没有addSkill方法的情况下解决这个addSkill 使用多重继承?

什么是最好的取决于很多因素。

使用您的vector<Skill*>版本:

  • 相同的Skill派生对象可以添加到多个Person对象中,这可能是内存高效且可取的,或者不合适的(例如,如果 Skills 对象必须具有Person特定的数据成员,例如技能的范围,例如 bench-新闻技能可能需要一些特定于Person的公斤数)
  • Skills派生对象的生命周期没有固有的管理,它必须永远超过通过您存储在Person对象中的指向它们的指针对它们的任何使用,否则您将获得未定义的行为 这可能很好:也许您可以在程序生命周期中创建一定数量的技能一次,并且不需要在所有Person对象的生命周期结束后销毁它们。 在其他时候,调用代码将承担额外的责任和照顾。

其他可能的方法包括:

Person存储vector<unique_ptr<Skill>> ,并让客户端代码将所有权移交给它添加的技能对象: addSkill(std::make_unique<SomeSkill>(constructor, args, la, de, da);

你也可以using SomeSkill = std::variant<Skill1, Skill2, Skill3>; 并让Person存储一个std::vector<SomeSkill> 这实现了与上一个类似的东西,但是在变体中使用了一个足够大的缓冲区来存储最大的Skill派生对象,而不是存储指向动态分配的Skill对象的指针。

您可以使用多重继承,但是您将有多个基类提供同名函数,并且要调用特定的函数,您必须在当时消除歧义。 如果您希望能够轻松声明具有不同技能的Person ,并且仍然有一个printSkills功能可以自动从多个基础中发现和打印单个技能,那么可以使用可变参数模板和参数包,但是从问题来看 - 恭敬- 你还没准备好走那条路。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM