我一直在尝试创建一个类型为Cmplx
的新变量(这是我的类名),其数据值为0且arg()
(arg是我班级的一种方法)
事实是结果变量的值为0,0。
有没有工作或者我做错了什么?
此外,代码:
#pragma once
#include <conio.h>
#include <stdio.h>
#include <iostream>
#include <string>
#include <cmath>
using namespace std;
template <typename vartype>
class Cmplx
{
public:
vartype Re, Im;
Cmplx(vartype const Real, vartype const Imag)//constructor
{
Re=Real;
Im=Imag;
}
long double arg()//called method
{
return atan2(Im,Re);
}
long double abs()
{
return sqrt(pow(Re,2)+pow(Im,2));
}
Cmplx<long double> log()//target method
{
Cmplx<long double> IArg(0,arg());
return IArg+log(abs());
}
Cmplx operator +(Cmplx const param)
{
Cmplx Tmp;
Tmp.Im=Im+param.Im;
Tmp.Re=Re+param.Re;
return Tmp;
}
Cmplx operator +(vartype const param)
{
Cmplx Tmp;
Tmp.Re=Re+param;
return Tmp;
}
friend Cmplx operator +(vartype const param, Cmplx const para)
{
Cmplx Tmp;
Tmp.Re=para.Re+param;
return Tmp;
}
friend ostream& operator << (ostream &tmp, Cmplx const ¶m)
{
tmp<<param.Re<<"+"<<param.Im<<"i";
return tmp;
}
friend istream& operator >> (istream &tmp, Cmplx ¶m)
{
tmp>>param.Re;
tmp>>param.Im;
return tmp;
}
};
template <>
class Cmplx<string>
{
public:
Cmplx()
{
cout << "Are you crazy or something?, a complex NUMBER with LETTERS as real part and imaginary part?"
<< "\n" << "Damn you should go to school dude." << endl;
}
};
template <>
class Cmplx<char>
{
public:
Cmplx<string> tmp;
};
template <typename type>
long double abs(Cmplx<type> param)
{
long double tmp;
tmp=sqrt(pow(param.Re,2)+pow(param.Im,2));
return tmp;
}
template <typename type>
long double arg(Cmplx<type> param)
{
return atan2(param.Im,param.Re);
}
template <typename type>
Cmplx<long double> exp(Cmplx <type> param)
{
Cmplx<long double> tmp, exim(cos(param.Im),sin(param.Im));
tmp=exp(param.Re)*exim;
return tmp;
}
template <typename type>
Cmplx <long double> log(Cmplx<type> param)
{
Cmplx<long double> IArg(0,arg(param));
return IArg+log(abs(param));
}
template <typename type, typename paramT>
Cmplx<long double> log_b(Cmplx<type> arg, paramT param)
{
return log(arg)/log(param);
}
该类的实现:
#include"cmplx oper.hpp"
using namespace std;
int main()
{
Cmplx<long double> A(2,3);
cout << log(A);
getch();
return true;
}
结果是:1.28247+0i
但它应该是1.28247+0.98279i
答案 0 :(得分:2)
看起来你实际上并不想传递方法本身 - 你想调用方法并将返回的值传递给构造函数。这正是你在这里做的,它应该没问题。换句话说,你所拥有的已大致相当于:
Cmplx<long double> log()
{
long double tmp = arg();
Cmplx<long double> IArg(0, tmp);
return IArg + log(abs());
}
我怀疑其他东西出了问题 - 例如你的对象没有你认为它开始的数据。我建议你在调试器中逐步执行代码,添加一些诊断日志记录,或添加一些单元测试来验证这个类,然后再使用它。
(顺便说一句,对于像这样的变量使用Pascal-case看起来很奇怪。我没有看到任何C ++约定那样做......)
编辑:我怀疑这是问题所在:friend Cmplx operator +(vartype const param, Cmplx const para)
{
Cmplx Tmp;
Tmp.Re=para.Re+param;
return Tmp;
}
请注意,除了para
之外,您永远不会使用para.Re
的任何部分,也绝不会分配给Tmp.Im
。我怀疑你想要:
friend Cmplx operator +(vartype const param, Cmplx const para)
{
Cmplx Tmp = para;
Tmp.Re += param;
return Tmp;
}
或者可能只是:
friend Cmplx operator +(vartype const param, Cmplx const para)
{
return Cmplx(para.Re + param, para.Im);
}