complex<float>
Popisuje objekt, který ukládá dvojici objednané objektů typu float*,* nejprve představující skutečné část komplexního čísla a druhý představuje imaginární část.
template<>
class complex<float> {
public:
complex(
float _RealVal = 0,
float _ImagVal = 0
);
complex(
const complex<float>& _ComplexNum
);
complex(
const complex<double>& _ComplexNum
);
complex(
const complex<long double>& _ComplexNum
);
// rest same as template class complex
};
Parametry
_RealVal
Hodnota typu float pro reálná část komplexního čísla nevytváří._ImagVal
Hodnota typu float pro imaginární část komplexního čísla jsou vyrobeny._ComplexNum
Komplexní číslo typu dvojité nebo long double jehož reálných a imaginárních částí slouží k inicializaci komplexního čísla typu float nevytváří.
Vrácená hodnota
Komplexní číslo typu float.
Poznámky
Explicitní specializace složité a komplexní třídu typu šablony třídy float se liší od šablony třídy pouze v definuje konstruktory.Převod z float k dvojité může být implicitní, ale méně bezpečný převod z float k long double musí být explicitní.Použití explicitní vylučuje zahájení s pomocí syntaxe přiřazení typ převodu.
Další informace o třídě šablony complex, viz complex – třída.Seznam členů třídy šablony complex, viz komplexní členů.
Příklad
// 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,"
<< "\n 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,"
<< "\n 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:\n arg ( c3 ) = "
<< argc3 << " radians, which is " << argc3 * 180 / pi
<< " degrees." << endl;
}
Požadavky
Záhlaví: <komplexní>
Obor názvů: std
Viz také
Referenční dokumentace
Bezpečný přístup z více vláken ve standardní knihovně C++