complex<double>
Descreve um objeto que armazena um par ordenado de objetos do tipo double*,* o primeiro que representa a parte real de um número complexo e a segunda que representa a parte imaginária.
template<>
class complex<double> {
public:
complex(
double _RealVal = 0,
double _ImagVal = 0
);
complex(
const complex<double>& _ComplexNum
);
explicit complex(
const complex<long double>& _ComplexNum
);
// rest same as template class complex
};
Parâmetros
_RealVal
O valor do tipo double para a parte real do número complexo que está sendo construída._ImagVal
O valor do tipo double para a parte imaginária do número complexo que está sendo construída._ComplexNum
O número complexo do tipo float ou do tipo long double cujas partes real e imaginária são usados para inicializar um número complexo do tipo double sendo construído.
Valor de retorno
Um número complexo do tipo double.
Comentários
A especialização explícita da classe modelo complexa para uma classe complexa do tipo double difere somente em construtores ele define a classe de modelo.A conversão de float para double pode ser implícito, mas a conversão de long double para double é necessário para ser explícita.O uso de explícita rege o início com a conversão de tipo usando a sintaxe de atribuição.
Para obter mais informações sobre a classe de modelo complex, consulte complex Class.Para obter uma lista de membros de classe de modelo complex, consulte Membros complexos.
Exemplo
// complex_comp_dbl.cpp
// compile with: /EHsc
#include <complex>
#include <iostream>
int main( )
{
using namespace std;
double pi = 3.14159265359;
// The first constructor specifies real & imaginary parts
complex <double> c1 ( 4.0 , 5.0 );
cout << "Specifying initial real & imaginary parts,\n"
<< " as type double gives c1 = " << c1 << endl;
// The second constructor initializes values of the real &
// imaginary parts using those of complex number of type float
complex <float> c2float ( 4.0 , 5.0 );
complex <double> c2double ( c2float );
cout << "Implicit conversion from type float to type double,"
<< "\n gives c2double = " << c2double << endl;
// The third constructor initializes values of the real &
// imaginary parts using those of a complex number
// of type long double
complex <long double> c3longdouble ( 4.0 , 5.0 );
complex <double> c3double ( c3longdouble );
cout << "Explicit conversion from type float to type double,"
<< "\n gives c3longdouble = " << c3longdouble << endl;
// The modulus and argument of a complex number can be recovered
double absc3 = abs ( c3longdouble );
double argc3 = arg ( c3longdouble );
cout << "The modulus of c3 is recovered from c3 using: abs ( c3 ) = "
<< absc3 << endl;
cout << "Argument of c3 is recovered from c3 using:\n arg ( c3 ) = "
<< argc3 << " radians, which is " << argc3 * 180 / pi
<< " degrees." << endl;
}
Requisitos
Cabeçalho: <complex>
Namespace: std
Consulte também
Referência
Segurança do thread na biblioteca C++ padrão