Sdílet prostřednictvím


complex<long double>

Tato explicitně specializovaná šablona třídy popisuje objekt, který ukládá seřazený pár objektů, oba typy long double, první představující skutečnou část komplexního čísla a druhou představující imaginární část.

Syntax

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

Parameters

_RealVal
Hodnota typu long double pro skutečnou část komplexního čísla, která se sestavuje.

_ImagVal
Hodnota typu long double pro imaginární část komplexního čísla, která se sestavuje.

complexNum
Komplexní počet typů double nebo typů float , jejichž skutečné a imaginární části se používají k inicializaci komplexního počtu vytvářených typů long double .

Return Value

Komplexní počet typů long double.

Remarks

Explicitní specializace šablony complex třídy na komplexní třídu typu long double se liší od šablony třídy pouze v konstruktorech, které definuje. Převod z long double na float je povolen implicitní, ale převod z double na long double je nutné .explicit Použití explicit pravidel inicializace s převodem typů pomocí syntaxe přiřazení.

Další informace o šabloně complex třídy a jejích členech najdete v tématu complex Třída.

Microsoft-specific: The long double and double types have the same representation, but are distinct types. For more information, see Built-in types.

Example

// 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.

Requirements

Header: <complex>

Namespace:std

See also

complex Třída
Bezpečný přístup z více vláken ve standardní knihovně C++