Namespaces
Variants

std::moneypunct<CharT,International>:: decimal_point, do_decimal_point

From cppreference.net
Défini dans l'en-tête <locale>
public :
CharT decimal_point ( ) const ;
(1)
protected :
virtual CharT do_decimal_point ( ) const ;
(2)
1) Fonction membre publique, appelle la fonction membre do_decimal_point de la classe la plus dérivée.
2) Retourne le caractère à utiliser comme séparateur décimal dans les entrées/sorties monétaires si le format utilise des fractions (c'est-à-dire si do_frac_digits() est supérieur à zéro). Pour les paramètres régionaux américains typiques, c'est le caractère '.' (ou L '.' ).

Valeur de retour

L'objet de type CharT contenant le caractère de séparation décimale.

Exemple

#include <iomanip>
#include <iostream>
#include <locale>
void show_dpt(const char* locname)
{
    std::locale loc(locname);
    std::cout.imbue(loc);
    std::cout << locname << " decimal point is '"
              << std::use_facet<std::moneypunct<char>>(loc).decimal_point()
              << "' for example: " << std::showbase << std::put_money(123);
    if (std::use_facet<std::moneypunct<char>>(loc).frac_digits() == 0)
        std::cout << " (does not use frac digits)";
    std::cout << '\n';
}
int main()
{
    show_dpt("en_US.utf8");
    show_dpt("ja_JP.utf8");
    show_dpt("sv_SE.utf8");
    show_dpt("de_DE.utf8");
}

Sortie :

en_US.utf8 decimal point is '.' for example: $1.23
ja_JP.utf8 decimal point is '.' for example: ¥123 (does not use frac digits)
sv_SE.utf8 decimal point is ',' for example: 1,23 kr
de_DE.utf8 decimal point is ',' for example: 1,23 €

Voir aussi

fournit le nombre de chiffres à afficher après la virgule décimale
(fonction membre protégée virtuelle)