Condividi tramite


complex<float>

Descrive un oggetto che archivia una coppia ordinata di oggetti, entrambi di tipo float, di cui il primo rappresenta la parte reale di un numero complesso e il secondo rappresenta la parte immaginaria.

Sintassi

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

constexpr complex(
    const complex<float>& complexNum);

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

constexpr complex(
    const complex<long double>& complexNum);
// rest same as class template complex
};

Parametri

_RealVal
Valore di tipo float per la parte reale del numero complesso costruito.

_ImagVal
Valore di tipo float per la parte immaginaria del numero complesso che viene costruito.

complexNum
Numero complesso di tipo o di tipo double long double le cui parti reali e immaginarie vengono utilizzate per inizializzare un numero complesso di tipi float da costruire.

Valore restituito

Numero complesso di tipo float.

Osservazioni:

La specializzazione esplicita del modello di classe complessa per una classe complessa di tipo float differisce dal modello di classe solo nei costruttori definiti. La conversione da float a double può essere implicita, ma la conversione da float a long double meno sicura 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 complexdi classe , vedere Classe complessa. Per un elenco dei membri del modello complexdi classe , vedere .

Esempio

// complex_comp_flt.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 <float> 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 double
   complex <double> c2double ( 1.0 , 3.0 );
   complex <float> c2float ( c2double );
   cout << "Implicit conversion from type double to type float,"
        << endl << "gives c2float = " << c2float << 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 ( 3.0 , 4.0 );
   complex <float> c3float ( c3longdouble );
   cout << "Explicit conversion from type long double to type float,"
        << endl << "gives c3float = " << c3float << endl;

   // The modulus and argument of a complex number can be recovered
   double absc3 = abs ( c3float);
   double argc3 = arg ( c3float);
   cout << "The modulus of c3 is recovered from c3 using: abs ( c3 ) = "
        << absc3 << endl;
   cout << "Argument of c3 is recovered from c3 using:"
        << endl << "arg ( c3 ) = "
        << argc3 << " radians, which is " << argc3 * 180 / pi
        << " degrees." << endl;
}
/* Output:
Specifying initial real & imaginary parts,
as type float gives c1 = (4,5)
Implicit conversion from type double to type float,
gives c2float = (1,3)
Explicit conversion from type long double to type float,
gives c3float = (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++)