lar*_*pco 6 c++ virtual-inheritance diamond-problem
我有三个类这样的结构:
#include <iostream>
using namespace std;
class Keyword
{
public:
virtual float GetValue() = 0;
};
class CharacterKeyword : public Keyword
{
public:
virtual float GetValue(){return _value;}
private:
float _value;
};
class MeasurementKeyword : public Keyword
{
public:
virtual float GetValue(){return _value;}
private:
float _value;
};
class AddressType : public CharacterKeyword, public MeasurementKeyword
{
private:
float address;
float addresExt;
};
int main()
{
AddressType *a = new AddressType();
a->GetValue();
return 0;
}
Run Code Online (Sandbox Code Playgroud)
我得到以下内容:
In function ‘int main()’:
error: request for member ‘GetValue’ is ambiguous
error: candidates are: virtual float Keyword::GetValue()
error: virtual float MeasurementKeyword::GetValue()
error: virtual float CharacterKeyword::GetValue()
我已经对多重继承做了一些阅读,我知道它有很多陷阱 - 这就是其中之一.我需要我的类结构是这样的,所以我想知道是否有一种方法可以使用模板来解决这个问题?
更新
阅读完你的评论之后,我原来的想法是,我可以在一个AddressType是a CharacterKeyword和AddressType一个MeasurementKeyword通过模板化之间描绘AddressType.并在更新的代码中使用它.或者我可以指定我想要的成员的名称空间.由于模板化的方式尚未被提及作为答案,这是一个糟糕的解决方案吗?我应该只指定我想要的成员的名称空间吗?
template <class T>
class AddressType : public T
{
private:
float address;
float addresExt;
};
int main()
{
AddressType<MeasurementKeyword> *a = new AddressType<MeasurementKeyword>();
a->GetValue();
return 0;
}
Run Code Online (Sandbox Code Playgroud)
aar*_*man 16
这是因为钻石继承模式,要解决错误,您可以指定您希望该成员的特定命名空间.
paddressType->MeasurementKeyword::GetValue()
Run Code Online (Sandbox Code Playgroud)
要么
paddressType->CharacterKeyword::GetValue()
Run Code Online (Sandbox Code Playgroud)
AddressType类可以GetValue从它继承的类中访问成员,也不能选择一个(调用不明确).::)有助于确定你真正想要哪一个.小智 6
像这样定义AddressType:
class AddressType : public CharacterKeyword, public MeasurementKeyword
{
public:
using MeasurementKeyword::GetValue;
private:
float address;
float addresExt;
};
Run Code Online (Sandbox Code Playgroud)