运算符超载:成员与非会员当仅涉及相同类型的对象时
Operator overload: Member vs. non-member when only same type objects can be involved
这个问题给出了一个很好的答案,为什么将操作员超载定义为非会员:操作员重载:成员函数与非成员函数?
如果将操作员定义为成员函数,则 然后,编译器将S1 S2这样的表达式转换为 S1.EPERATOR (S2)。这意味着操作员超载成员功能 在第一台操作数上被调用。这就是成员功能的工作方式!
但是,如果第一操作数不是类?有一个主要问题 如果我们想超载第一操作数不是一个操作员 班级类型,而是说双重。所以你不能像这个10.0 那样写 S2。但是,您可以为操作员编写超载成员功能 S1 10.0等表达式。
现在,我有一个需要超载operator==
的情况。就我而言,将比较(b)相同类型的对象。
是否有理由将operator==
定义为非会员,或者我应该在这种情况下以成员的形式实现它?
,因为operator==
具有其LHS和RHS参数的对称语义,因此推荐的方法是始终根据其操作数的公共界面(或者私人数据的公共接口)将其实现为非会员需要将其声明为班上的朋友)。
so
class Bla
{
public:
// complete interface to data required for comparison
auto first();
auto second();
// ... more
private:
// data goes here
};
bool operator==(Bla const& L, Bla const& R)
{
return
std::forward_as_tuple(L.first(), L.second() /*, ... */) ==
std::forward_as_tuple(R.first(), R.second() /*, ... */)
;
}
以这种方式,考虑到L和R参数的隐式转换为Bla
(我并不是说隐式转换是一个好主意,但是如果您有这些,最好避免出现惊喜RHS参数)。
相关文章:
- std::unordered_map 类型对象声明期间出现"field has incomplete type"错误
- C++ 多态模板类,模板类型对象的实例化
- 如何分配适合容纳 T 类型对象的缓冲区(可能过度对齐、可能有运算符 new 等)
- 如何构造一个 std::variant 类型对象,其自身 Templated 和构造函数转发参数
- C++:初始化指向具有不同类型对象的指针数组
- 在类 C++ 中构造的模板类型对象
- 如何为同一类对象的成员函数保留单独的变量副本?
- 如何将颁发者名称设置为x509_req类型对象
- 将任何数据类型/对象作为参数传递以确定其大小
- 如何使用nullptr初始化同一类对象的静态指针数组?
- 将引用类型对象的数组从C#封送到C++
- <T> 从类型对象创建类型<T1>对象的构造函数
- RocksDB是存储同质对象的好选择吗
- C++是否有现有的方法来检查对象是否是派生类型对象
- C 模板:创建与现有对象相同的类型对象
- 链接列表中的虚函数 - 多种返回类型(对象)
- 没有适当操作员()的类型对象的呼叫
- 制作垫子类型对象的数组.输出窗口显示同一帧
- 抽象类型对象的分配
- 在std::list中就地创建自定义类型对象