Compartir vía


complex<long double>

Esta plantilla de clase especializada de forma explícita describe un objeto que almacena un par ordenado de objetos, ambos de tipo long double; el primero representa la parte real de un número complejo y el segundo la parte imaginaria.

Sintaxis

template <>
class complex<long double> {
public:
    constexpr complex(
    long double _RealVal = 0,
    long double _ImagVal = 0);

complex(
    constexpr complex<long double>& complexNum);

// rest same as class template complex
};

Parámetros

_RealVal
Valor de tipo long double de la parte real del número complejo que se está construyendo.

_ImagVal
Valor de tipo long double de la parte imaginaria del número complejo que se está construyendo.

complexNum
Número complejo de tipo double o float cuyas partes real e imaginaria se usan para inicializar un número complejo de tipo long double que se está construyendo.

Valor devuelto

Número complejo de tipo long double.

Comentarios

La especialización explícita de la plantilla de clase complex para una clase compleja de tipo long double solo se distingue de la plantilla de clase en los constructores que define. Se permite que la conversión de long double a float sea implícita, pero la conversión de double a long double debe ser explicit. El uso de explicit descarta el inicio con conversión de tipos mediante sintaxis de asignación.

Para obtener más información sobre la plantilla de clase complex y sus miembros, vea complex (Clase).

Específico de Microsoft: los tipos long double y double tienen la misma representación, pero son tipos distintos. Para obtener más información, vea Tipos integrados.

Ejemplo

// complex_comp_ld.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<long double> c1( 4.0 , 5.0 );
    cout << "Specifying initial real & imaginary parts,\n"
        << " as type float 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( 1.0 , 3.0 );
    complex<long double> c2longdouble ( c2float );
    cout << "Implicit conversion from type float to type long double,"
        << "\n gives c2longdouble = " << c2longdouble << endl;

    // The third constructor initializes values of the real &
    // imaginary parts using those of a complex number
    // of type double
    complex<double> c3double( 3.0 , 4.0 );
    complex<long double> c3longdouble( c3double );
    cout << "Implicit conversion from type long double to type float,"
        << "\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;
}
Specifying initial real & imaginary parts,
as type float gives c1 = (4,5)
Implicit conversion from type float to type long double,
gives c2longdouble = (1,3)
Implicit conversion from type long double to type float,
gives c3longdouble = (3,4)
The modulus of c3 is recovered from c3 using: abs( c3 ) = 5
Argument of c3 is recovered from c3 using:
arg( c3 ) = 0.927295 radians, which is 53.1301 degrees.

Requisitos

Encabezado: <complex>

Espacio de nombres: std

Consulte también

complex (Clase)
Seguridad para subprocesos en la biblioteca estándar de C++