Compartir a través de


complex<long double>

Describe un objeto que almacena un par orden de objetos ambos de long doublecon tipo, del primer que representa la parte real de un número complejo y el segundo que representa la parte imaginaria.

template<>
   class complex<long double> {
public:
   complex(
      long double _RealVal = 0, 
      long double _ImagVal = 0
   );
complex(
      const complex<long double>& _ComplexNum
   );
   // rest same as template class complex
};

Parámetros

  • _RealVal
    El valor de doble largo escrito para la parte real de números complejos que es construido.

  • _ImagVal
    El valor de long double escrito para la parte imaginaria de números complejos que es construido.

  • _ComplexNum
    El número complejo de Doble cualquiera de Hacer flotante tipo cuyo las partes real e imaginarias se utilizan para inicializar un número complejo de long double cuyas es construido.

Valor devuelto

un número complejo de long doubleescrito.

Comentarios

La especialización explícita complejo de la clase de plantilla a una clase compleja de long double tipo difiere de la clase de plantilla solo en los constructores que define.La conversión de long double a Hacer flotante puede ser implícita, pero la conversión de Doble a long double es necesario que explícito.El uso de explícito elimina el inicio con la conversión de tipos mediante sintaxis de asignación.

Para obtener más información sobre la clase de plantilla complex, vea complex Class.Para obtener una lista de miembros de la clase de plantilla complex, vea miembros complejos.

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;
}
  

Requisitos

Encabezado: <complejo>

espacio de nombres: std

Vea también

Referencia

complex Class

Seguridad para subprocesos de la biblioteca estándar de C++

Otros recursos

miembros de <complejo>

miembros complejos