操作过载*(左侧和右侧)
operation overloading * (both left side and right side)
本文关键字:操作 更新时间:2023-10-16
我有一个类Mat
class Mat
{
..
..
..
friend Mat& operator*(Mat s1,int elem){
s1.multiWith(elem);
return s1;
}
};
现在它将适用于m1*2但是如何使其与2*m1
现在它将适用于m1*2,但如何使它适用于2*m1
为其提供另一个过载。
class Mat
{
..
friend Mat operator*(const Mat& s1, int elem) {
Mat ret = s1;
ret.multiWith(elem);
return ret;
}
friend Mat operator*(int elem, const Mat& s1) {
return s1 * elem;
}
};
BTW1:operator*
应按值返回Mat
,而不是按引用返回
BTW2:为了避免复制,您可能需要将s1
的参数类型更改为常量引用
BTW3:如果Mat::multiWith
不是private
,则operator*
不必是friend
。
a*b
运算符应该返回一个新对象,而不是对a
的引用。
在类中声明operator*
的正确语法是:
class Mat
{
..
..
..
Mat operator*(int elem){
Mat res = *this;
res.multiWith(elem);
return res;
}
};
那么,左参数的类型必然是当前类(这里:a*b
的左参数必然是Mat
实例)。
现在,如果您在类之外声明运算符,您可以自由地为左右参数选择任何类型:
class Mat
{
};
Mat operator*(const Mat& left,int right){
Mat res;
// do res=left*elem
return res;
}
Mat operator*(int left,const Mat& right){
Mat res;
// do res=left*right
return res;
}
相关文章:
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 重载操作程序时出错>>用于类中的字符串 memebr
- 对字符串进行位操作
- 我可以在 C++ 中的函数体之外进行操作吗?
- MPI突然停止了对多个核心的操作
- 如何在信号处理程序和普通函数中对全局变量进行互斥读写操作
- 对字符数组中的元素执行逐位操作
- 如何在directx/c++中进行平移/缩放操作
- 逐位操作的隐式类型转换
- 为什么一个向量上的多线程操作很慢
- 排序时无法执行交换操作.我做的时候它会崩溃.为什么
- 位移操作和位掩码未检测到重复字符
- 如何进行特定的位操作?
- 当我们进行一些操作时,应该使用什么'std::string'或'std::stringstream'?
- 字符串操作 - 字符计数
- 此代码中的操作流程是什么?C/C++.
- 复制和交换习惯用法与移动操作之间的交互
- 像union_这样的 Boost.Geometry 操作如何处理浮点类型的基本不精确性?
- 为什么 std::lerp 不适用于任何已实现所需操作的类型?
- 无法合并生成操作.. 先决条件不同