C++子类重载乘法运算符隐藏基重载取消引用运算符
C++ Subclass Overloaded Multiplication Operator Hides Base Overloaded Dereference Operator
是否可以在类继承的不同级别覆盖operator*()
(一元解引用运算符(和operator*(double f)
(具有本机double
参数的成员二进制乘法(?
考虑:
// base.h:
template<typename T>
class base {
public:
base(T v) : m_v(v) { }
T& operator*() { return m_v; }
const T& operator*() const { return m_v; }
protected:
T m_v;
};
和
// special.h:
#include "base.h"
class super_double : public base<double> {
public:
super_double (double v) : base(v) { }
const super_double operator* (double f) { return super_double (m_v * f); }
};
我不明白为什么成员二进制operator*
隐藏从基类继承的去引用运算符,因为它们的调用约定不同。如果super_double
没有定义operator*(double f)
,则以下代码编译良好,但如果定义了,则会发出错误:
super_double q(289.3);
double d = *q; // Only good if super_double doesn't define operator*(double f)
如果operator*
的两种形式都在模板基类中定义,也可以。
为什么子类的二进制operator*(double f)
隐藏基类的一元operator*()
?
在C++中,名称查找是重载解析的单独步骤。名称查找是查找与名称相关的作用域的过程。
引入名称Derived::operator*
意味着在Derived
在范围内的点搜索operator*
(或使用*
作为运算符(,将名称解析为Derived::operator*
。然后对于存在CCD_ 15的任何过载进行过载解析。
要获得过载解决方案,还需要考虑当前命名为Base::operator*
的函数,您需要通过编写以下内容将这些函数引入Derived
中:
using Base::operator*;
在CCD_ 18类中。这意味着名称Derived::operator*
现在指的是这三个函数,重载解析将在其中进行选择。
我不明白为什么成员二进制
operator*
隐藏了从基类继承的去引用运算符
因为他们有相同的名字。假设C++可能有一个规则,即运算符函数的名称查找只考虑具有正确数量参数的函数,但在C++语言中没有这样的规则。
您可以用通常的方法修复这个问题:在派生类定义中使用using base::operator*;
。
可能更好的方法是将其实现为二进制友元函数来消除歧义。
template<typename T>
class base {
public:
base(T v) : m_v(v) { }
T& operator*() { return m_v; }
const T& operator*() const { return m_v; }
protected:
T m_v;
};
class super_double : public base<double> {
public:
super_double (double v) : base(v) { }
friend const super_double operator* (const super_double& d, double f) { return super_double (d.m_v * f); }
};
int main()
{
super_double q(289.3);
double d = *q;
std::cout << d <<'n';
}
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- <T> 通过模板化运算符重载将 std::complex 乘以双倍
- C++20概念:需要运算符重载
- 使用赋值运算符重载从类中返回jobject
- 在运算符重载定义中使用成员函数(const错误)
- 字节到位运算符重载C++
- 为什么在运算符重载时需要参考?
- 类中 c++ 的运算符 + 重载
- 算术复合运算符重载为非成员
- 运算符重载 (+),用于添加两个具有 C++ 的数组
- 交换运算符 + 重载会导致无限递归
- 如何理解新的运算符重载?
- 向量保持复数的运算符重载
- 如何创建运算符重载?
- 链接列表运算符重载没有打印出我想要的内容
- C++:需要帮助了解运算符重载错误
- 使用模板化运算符重载 XOR 运算符失败
- 如何确保接受的C++模板类型使运算符重载?
- 运算符重载使用运算符+添加类模板