C++ 如何重载关系运算符以检查两个对象是否相同
C++ How can I overload relational operators to check if two objects are the same?
我正在尝试重载关系运算符(==,>,<,>=,<=),但是如果两个对象不同,我希望能够返回false,而不是返回错误。例如,我有一个 ArrayList 类和一个当前无法比较的 Vector 类。我怎样才能做到这一点?
尝试类似以下内容:
#include <iostream>
class ArrayList {};
class Vector {};
bool operator==(Vector const &v, ArrayList const &al) { return false; }
bool operator==(ArrayList const &al, Vector const &v) { return false; }
int main()
{
ArrayList al;
Vector v;
std::cout << (al == v ? "true" : "false") << std::endl;
std::cout << (v == al ? "true" : "false") << std::endl;
return 0;
}
两种比较都将打印为假;
使用模板编辑:
#include <iostream>
#include <type_traits>
class ArrayList {};
class Vector {};
class Whatever {};
template <class T, class U> bool operator==(T const &, U const &)
{
return std::is_same<T, U>::value;
}
int main()
{
ArrayList al;
Vector v;
Whatever w;
std::cout << (al == v ? "true" : "false") << std::endl;
std::cout << (v == al ? "true" : "false") << std::endl;
std::cout << (w == v ? "true" : "false") << std::endl;
std::cout << (w == w ? "true" : "false") << std::endl;
return 0;
}
如果类相同,这将简单地返回 true,如果不是,这将返回 false。
相关文章:
- 如何检查两个 std::向量在小于 O(n) 的时间复杂度内是否相等
- 是否可以在 OpenGL 中的同一调用中呈现两个具有不同索引起点的不同缓冲区?
- 检查两个节点在子节点上是否具有相同状态的更优雅的方法
- 如何巧妙地编写两个函数——一个用于检查是否存在解决方案,另一个用于获取所有解决方案
- 使用XOR查找O(n)-解决方案中的两个字符串是否为变位符
- 给定一个大小为 N 的数组 S,检查是否可以将序列拆分为两个序列
- 具有相同特征的两个对象是否只在内存中存储一次?无论定义它们的函数是什么,都是不同的
- 如何更好地检查两个 char 变量是否在一组值中?
- 是否有一种标准方法来计算两个 asctime() 值之间的天数
- 是否可以使用非常量指针调用非常量函数,以及当两个unique_ptrs指向同一个对象时程序的行为方式?
- 检查两个模板参数是否相同
- 是否可以在 for 循环中添加两个浮点数?
- 是否允许三元运算符在C++中计算两个操作数?
- 使用 SET(C++) 检查两个给定字符串是否是字谜时出现运行时错误
- 使用 std::vector::swap 方法在C++中交换两个不同的向量是否安全?
- 检查两个向量是否并行的最有效方法
- 检查两个图是否为补码的功能
- gtest:检查字符串是否等于两个字符串之一
- 如何在c/c++中检查两个任意内存范围是否重叠
- 图问题:找出两个节点是否在每个节点的O(1)时间和O(2)存储中共享同一分支