没有可行的过载+=,为什么
No Viable Overloaded +=, why?
本文关键字:为什么 更新时间:2023-10-16
用户定义类型的加法是由运算符+定义的,但+=没有解析为它,为什么?
typedef std::array<std::uint64_t,4> myvec_t;
inline myvec_t operator+(myvec_t foo, myvec_t bar){return mod_add(foo,bar);}
myvec_t a,b;
a+=b; // g++ says: error: no viable overloaded '+='
编辑:几个人充分回答了这个狭隘的问题,我会的接受一个答案,解释为什么标准允许人们超负荷地"+="(a,b(做一些不同于a=a+b?
您声明/定义operator+
的重载并传递和return
副本:
inline myvec_t operator+(myvec_t foo, myvec_t bar){return mod_add(foo,bar);}
您想重载operator+=
并传递和return
引用(假设mod_add
返回其结果(:
inline myvec_t& operator+=(myvec_t& foo, const myvec_t& bar)
{
foo = mod_add(foo, bar);
return foo;
}
因为您没有证明operator+=
过载,所以您为operator+
提供了过载
operator+=
过载由完成
inline myvec_t& operator+=(myvec_t& foo, const myvec_t& bar)
{
foo = mod_add(foo,bar);
return foo;
}
请注意,operator+
实现非常无效,因为它复制了操作数并返回了对象的一个副本,而总共只复制了1个副本(后者(。
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 为什么 std::unique 不调用 std::sort?
- 既然存在危险,为什么项目要使用-I include开关
- 为什么在运行时没有向我们提供有关分段错误的更多信息?