正在解决跨基类的虚拟方法重载
Resolving virtual method overloads across base classes
Visual Studio 2013。
给定:
class base_1
{
public:
virtual void foo(int) = 0;
};
class base_2
{
public:
virtual void foo(int, double) = 0;
};
class join_1_2 : public virtual base_1, public virtual base_2
{};
我有一个水槽:
void sink(join_1_2 ¶m)
{
param.foo(42, 3.14);
}
但我得到以下编译器错误:
错误C2385:"foo"的访问不明确
可能是基"base_1"中的"foo"
或者可以是基础"base_2"中的"foo"
错误C2660:"base_1::foo":函数不接受2个参数
错误C3861:"foo":找不到标识符
我知道我可以用解决这个问题
param.base_2::foo(42, 3.14);
但正如你所能想象的,虚拟继承已经是我不得不忍受的一种罪过。我可能要写一个适配器。但我不明白是什么阻止编译器尝试在base_2中解析foo。我的同事认为这是一个编译器错误,但我并没有那么快责怪供应商。
C++规范对跨基类解决重载虚拟方法有何规定?
根据标准,这确实是模糊的,但您可以使用using
或显式指定基类:
class join_1_2 : public virtual base_1, public virtual base_2
{
public:
using base_1::foo;
using base_2::foo;
};
void sink(join_1_2 ¶m)
{
param.base_2::foo(42, 3.14);
}
7.3.3使用声明
为了解决过载问题,通过using声明引入到派生类将被视为派生类的成员。
经验法则是不同作用域中的函数不会重载-这里我们的foo
位于不同的作用域中。如果你想让它们过载,你会想用使用声明将它们引入:
class join_1_2 : public virtual base_1, public virtual base_2
{
public:
using base_1::foo;
using base_2::foo;
};
相关文章:
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- CPP 继承虚拟方法解析顺序
- 我是否应该在包含虚拟方法的类上使用'memcpy'?如果没有,如何替换它?
- 用c++中的纯虚拟方法抽象模板类
- 解决虚拟方法的歧义继承的两种方法
- 没有针对完全专用模板类的外联虚拟方法定义