Udostępnij za pośrednictwem


money_get::get

Wyodrębnia wartość liczbową z sekwencję znaków, który reprezentuje wartość pieniężną.

iter_type get(
   iter_type _First, 
   iter_type _Last,
   bool _Intl, 
   ios_base& _Iosbase, 
   ios_base::iostate& _State,
   long double& _Val
) const;
iter_type get(
   iter_type _First, 
   iter_type _Last,
   bool _Intl, 
   ios_base& _Iosbase, 
   ios_base::iostate& _State,
   string_type& _Val
) const;

Parametry

  • _First
    Adresowanie początku sekwencji do konwersji wejściowych iteratora.

  • _Last
    Adresowanie koniec sekwencji do konwersji wejściowych iteratora.

  • _Intl
    Wartość logiczna, wskazująca typ oczekiwany w sekwencji symbol waluty: true Jeśli międzynarodowych, false Jeśli krajowych.

  • _Iosbase
    Flaga format, który podczas zestaw wskazuje, że symbol waluty jest opcjonalny; w przeciwnym razie jest wymagane

  • _State
    Ustawia elementy odpowiednie maski stanie strumienia, czy udało się działania zgodnie z.

  • _Val
    Ciąg przechowywania sekwencji przekonwertowane.

Wartość zwracana

Wejściowy iteratora adresowania pierwszy element poza pieniężnej pole wejściowe.

Uwagi

Both member functions return do_get(_First, _Last, _Intl, _Iosbase, _State, _Val).

Przykład

// money_get_get.cpp
// compile with: /EHsc
#include <locale>
#include <iostream>
#include <sstream>
using namespace std;

int main( )
{
   locale loc( "german_germany" );

   basic_stringstream< char > psz;
   psz << use_facet<moneypunct<char, 1> >(loc).curr_symbol() << "-1.000,56";
   basic_stringstream< char > psz2;
   psz2 << "-100056" << use_facet<moneypunct<char, 1> >(loc).curr_symbol();

   ios_base::iostate st = 0;
   long double fVal;

   psz.flags( psz.flags( )|ios_base::showbase ); 
   // Which forced the READING the currency symbol
   psz.imbue(loc);
   use_facet < money_get < char > >( loc ).
      get( basic_istream<char>::_Iter( psz.rdbuf( ) ),   
           basic_istream<char>::_Iter( 0 ), true, psz, st, fVal );

   if ( st & ios_base::failbit )
      cout << "money_get(" << psz.str( ) << ", intl = 1) FAILED"
           << endl;
   else
      cout << "money_get(" << psz.str( ) << ", intl = 1) = " 
           << fVal/100.0 << endl;

   use_facet < money_get < char > >( loc ).
      get(basic_istream<char>::_Iter(psz2.rdbuf( )),   
          basic_istream<char>::_Iter(0), false, psz2, st, fVal);

   if ( st & ios_base::failbit )
      cout << "money_get(" << psz2.str( ) << ", intl = 0) FAILED" 
           << endl;
   else
      cout << "money_get(" << psz2.str( ) << ", intl = 0) = " 
           << fVal/100.0 << endl;
};

Przykładowe dane wyjściowe

Po uruchomieniu systemu Windows 2000 lub starszego, uzyskanie takich danych wyjściowych:

money_get(DEM-1.000,56, intl = 1) = -1000.56
money_get(-100056DM, intl = 0) = -1000.56

System Windows XP, uzyskanie takich danych wyjściowych:

money_get(EUR-1.000,56, intl = 1) = -1000.56
money_get(-100056EUR, intl = 0) = -1000.56

Wymagania

Nagłówek: <locale>

Obszar nazw: std

Zobacz też

Informacje

money_get Class