complex<long double>
Questo modello di classe specializzato in modo esplicito descrive un oggetto che archivia una coppia ordinata di oggetti, entrambi di tipo long double
, il primo che rappresenta la parte reale di un numero complesso e il secondo che rappresenta la parte immaginaria.
Sintassi
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
};
Parametri
_RealVal
Valore di tipo long double
per la parte reale del numero complesso costruito.
_ImagVal
Valore di tipo long double
per la parte immaginaria del numero complesso che viene costruito.
complexNum
Numero complesso di tipo o di tipo double
float
le cui parti reali e immaginarie vengono utilizzate per inizializzare un numero complesso di tipi long double
da costruire.
Valore restituito
Numero complesso di tipo long double
.
Osservazioni:
La specializzazione esplicita del modello complex
di classe in una classe complessa di tipo long double
differisce dal modello di classe solo nei costruttori definiti. La conversione da long double
a float
può essere implicita, ma la conversione da double
a long double
deve essere explicit
. Uso delle regole per l'avvio con la conversione dei tipi usando la sintassi di explicit
assegnazione.
Per altre informazioni sul modello complex
di classe e sui relativi membri, vedere Classe complessa.
Specifico di Microsoft: i long double
tipi e double
hanno la stessa rappresentazione, ma sono tipi distinti. Per altre informazioni, vedere Tipi predefiniti.
Esempio
// 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.
Requisiti
Intestazione: <complessa>
Spazio dei nomi: std
Vedi anche
Classe complex
Thread Safety in the C++ Standard Library (Sicurezza dei thread nella libreria standard C++)