Namespaces
Variants

std:: get_money

From cppreference.net
< cpp ‎ | io ‎ | manip
Definido en el encabezado <iomanip>
template < class MoneyT >
/*unspecified*/ get_money ( MoneyT & mon, bool intl = false ) ;
(desde C++11)

Cuando se utiliza en una expresión in >> get_money ( mon, intl ) , analiza la entrada de caracteres como un valor monetario, según lo especificado por el facet std::money_get de la configuración regional actualmente imbucida en in , y almacena el valor en mon .

La operación de extracción en in >> get_money ( mon, intl ) se comporta como una FormattedInputFunction .

Contenidos

Parámetros

mon - variable donde se escribirá el valor monetario. Puede ser long double o std::basic_string
intl - espera encontrar cadenas de moneda internacional requeridas si es true , espera símbolos de moneda opcionales en caso contrario

Valor de retorno

Un objeto de tipo no especificado tal que

  • si in es un objeto de tipo std:: basic_istream < CharT, Traits > , la expresión in >> get_money ( mon, intl )
    • tiene tipo std:: basic_istream < CharT, Traits > &
    • tiene valor in
    • se comporta como si llamara a f ( in, mon, intl )

donde la función f se define como:

template<class CharT, class Traits, class MoneyT>
void f(std::basic_ios<CharT, Traits>& str, MoneyT& mon, bool intl)
{
    using Iter = std::istreambuf_iterator<CharT, Traits>;
    using MoneyGet = std::money_get<CharT, Iter>;
    std::ios_base::iostate err = std::ios_base::goodbit;
    const MoneyGet& mg = std::use_facet<MoneyGet>(str.getloc());
    mg.get(Iter(str.rdbuf()), Iter(), intl, str, err, mon);
    if (err != std::ios_base::goodbit)
        str.setstate(err);
}

Ejemplo

#include <iomanip>
#include <iostream>
#include <locale>
#include <sstream>
int main()
{
    std::istringstream in("$1,234.56 2.22 USD  3.33");
    long double v1, v2;
    std::string v3;
    in.imbue(std::locale("en_US.UTF-8"));
    in >> std::get_money(v1) >> std::get_money(v2) >> std::get_money(v3, true);
    if (in)
        std::cout << std::quoted(in.str()) << " parsed as: "
                  << v1 << ", " << v2 << ", " << v3 << '\n';
    else
        std::cout << "Parse failed";
}

Salida:

"$1,234.56 2.22 USD  3.33" parsed as: 123456, 222, 333

Véase también

analiza y construye un valor monetario a partir de una secuencia de caracteres de entrada
(plantilla de clase)
(C++11)
formatea y emite un valor monetario
(plantilla de función)