复数运算符重载
operator overloading with complex numbers
我想重载*操作符,以便它将类的复杂子变量相乘并返回复杂的结果。我的想法如下:
#include <complex>
using namespace std;
class a{
public:
std::complex<double> x0;
...
};
template<class T> complex<T> operator*(const a &lfv, const a &rfv){
return lfv.x0*rfv.x0;
}
但是它不工作…有什么想法或评论吗?
您的类包含std::complex<double>
数据成员,并且不是模板。你需要一个非模板函数:
std::complex<double> operator*(const a& lfv, const a& rfv){
return lfv.x0*rfv.x0;
}
在您的示例中,模板函数无法从传递给它的参数中推断出返回类型
Complex class已经处理了这个问题,即它总是在乘法之后返回复杂的结果。
用法如下:
complex<double> p(10,20);
complex<double> q(2,3);
std::cout << p*q << endl;
输出是:
(-40,70)
或者你可以这样做:
class a{
public:
std::complex<double> x0;
};
complex<double> operator*(const a &lfv, const a &rfv){
return lfv.x0*rfv.x0;
}
int main()
{
a y;
y.x0 = complex<double>(10,20);
a z;
z.x0 = complex<double>(10,20);
std::cout << y*z << endl;
}
我无法想到一种方法来做你正在寻找的(从operator*
返回complex<T>
),因为operator*
不能自动扣除类型,所以你必须指定类型,如下面的例子所示:
a my_var1;
a my_var2;
complex<double> result = operator*<double>(my_var1, my_var2);
…或者你可以按照@juanchopanza的建议,不要使用operator*
的模板。
相关文章:
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 重载运算符new[]的行为取决于析构函数
- 为什么将值返回函数传递给重载=运算符对运算符函数有效,而对其他运算符无效
- 在 myVector 类中重载运算符 + 时出错
- 为什么常量词在重载运算符中不与 ostream 对象一起使用<<?
- 如何在 cpp 中重载运算符 +=?
- C++ 如何重载 [] 运算符并进行函数调用
- 重载运算符的范围是什么?它是否会影响作为类成员的集合的插入函数?
- 为什么我可以在不重载 "=" 运算符的情况下将一个对象分配给另一个对象?
- 重载运算符有地址吗?
- 如何迭代重载运算符 [] 的类?
- 重载运算符与添加问题
- 模板基类中的重载运算符
- 如何调用用于重载运算符"<<"的 friend 函数?
- 在 C++17 中的命名空间和子命名空间中重载运算符是不明确的
- 重载运算符<<采用谷歌 C++ 风格
- C++ 如何正确重载 + 运算符
- cout (<<) 重载运算符不打印减去的矩阵
- 如何在 c++ 中重载运算符 + 以便能够 whrite c_str = "smth" + c_str;
- 重载运算符*以获取对另一个类的实例的引用