本地化库
本地环境设施包含字符分类和字符串校对、数值、货币及日期/时间格式化和分析,以及消息取得的国际化支持。本地环境设置控制流 I/O 、正则表达式库和 C++ 标准库的其他组件的行为。
平面类别
定义 std::money_get 与 std::money_put 所用的货币格式解析器的参数
std::moneypunct
template< class CharT, bool International = false > |
平面 std::moneypunct 封装货币值格式化偏好。流 I/O 操纵符 std::get_money 和 std::put_money 通过 std::money_get 和 std::money_put 用 std::moneypunct 分析货币值输入及格式化货币值输出。
继承图
标准库提供四个孤立(独立于本地环境)的特化:
定义于头文件 | |
std::moneypunct<char> | 提供 "C" 本地环境偏好的等价版本 |
std::moneypunct<wchar_t> | 提供 "C" 本地环境偏好的宽字符等价版本 |
std::moneypunct<char, true> | 提供 "C" 本地环境偏好的等价版本,带国际通货符号 |
std::moneypunct<wchar_t, true> | 提供 "C" 本地环境偏好的宽字符等价版本,带国际通货符号 |
另外, C++ 程序中构造的每个 locale 对象都实装这些特化的其自身(本地环境限定)版本。
成员类型
成员类型 | 定义 |
char_type | CharT |
string_type | std::basic_string<CharT> |
成员函数
(构造函数) | 构造新的 moneypunct 平面 (公开成员函数) |
(析构函数) | 销毁 moneypunct 平面 (受保护成员函数) |
decimal_point | 调用 do_decimal_point (公开成员函数) |
thousands_sep | 调用 do_thousands_sep (公开成员函数) |
grouping | 调用 do_grouping (公开成员函数) |
curr_symbol | 调用 do_curr_symbol (公开成员函数) |
positive_signnegative_sign | 调用 do_positive_sign 或 do_negative_sign (公开成员函数) |
frac_digits | 调用 do_frac_digits (公开成员函数) |
pos_formatneg_format | 调用 do_pos_format /do_neg_format (公开成员函数) |
受保护成员函数
do_decimal_point [虚] | 提供用作小数点的字符 (虚受保护成员函数) |
do_thousands_sep [虚] | 提供用作千分隔符的字符 (虚受保护成员函数) |
do_grouping [虚] | 提供二个千分隔符间的位数 (虚受保护成员函数) |
do_curr_symbol [虚] | 提供用作通货标识符的字符串 (虚受保护成员函数) |
do_positive_signdo_negative_sign [虚] | 提供指示正或负值的字符串 (虚受保护成员函数) |
do_frac_digits [虚] | 提供小数点后要显示的位数 (虚受保护成员函数) |
do_pos_formatdo_neg_format [虚] | 提供通货值的格式化模式 (虚受保护成员函数) |
成员常量
成员 | 定义 |
const bool intl [静态] | International |
成员对象
static std::locale::id id | locale 的 id (公开成员对象) |
继承自 std::money_base
成员类型 | 定义 |
enum part { none, space, symbol, sign, value }; | 无作用域枚举类型 |
struct pattern { char field[4]; }; | 货币格式类型 |
枚举常量 | 解释 |
none | 容许但不要求空白符,除了在末位置不容许空白符 |
space | 要求一或多个空白字符 |
symbol | 要求 moneypunct::curr_symbol 所返回的字符序列 |
sign | 要求 moneypunct::positive_sign 或 moneypunct::negative_sign 所返回的首个字符 |
value | 要求绝对数值货币值 |
调用示例 windows
#include <iostream>
#include <sstream>
#include <locale>
#include <iomanip>
#include <vector>
#include <algorithm>
#include <iterator>
#include <exception>
#include <Windows.h>
std::vector<std::wstring> locals;
BOOL CALLBACK MyFuncLocaleEx(LPWSTR pStr, DWORD dwFlags, LPARAM lparam)
{
locals.push_back(pStr);
return TRUE;
}
std::string stows(const std::wstring& ws)
{
std::string curLocale = setlocale(LC_ALL, NULL); // curLocale = "C";
setlocale(LC_ALL, "chs");
const wchar_t* _Source = ws.c_str();
size_t _Dsize = 2 * ws.size() + 1;
char *_Dest = new char[_Dsize];
memset(_Dest, 0, _Dsize);
wcstombs(_Dest, _Source, _Dsize);
std::string result = _Dest;
delete[]_Dest;
setlocale(LC_ALL, curLocale.c_str());
return result;
}
void show_dpt(const char* locname)
{
std::locale locale(locname);
std::cout.imbue(locale);
std::cout << locale.name() << " decimal point is '"
<< std::use_facet<std::moneypunct<char>>(locale).decimal_point()
<< "' for example: " << std::showbase << std::put_money(123);
if (std::use_facet<std::moneypunct<char>>(locale).frac_digits() == 0)
{
std::cout << " (does not use frac digits) ";
}
std::cout << std::endl;
}
int main()
{
EnumSystemLocalesEx(MyFuncLocaleEx, LOCALE_ALTERNATE_SORTS, NULL, NULL);
for (std::vector<std::wstring>::const_iterator str = locals.begin();
str != locals.end(); ++str)
{
if (stows(*str) == "x-IV_mathan")
{
continue;
}
show_dpt(stows(*str).c_str());
}
return 0;
}
输出
de-DE_phoneb decimal point is ',' for example: 1,23 €
es-ES_tradnl decimal point is ',' for example: 1,23 €
hu-HU_technl decimal point is ',' for example: 1,23 Ft
ja-JP_radstr decimal point is '.' for example: \123 (does not use frac digits)
ka-GE_modern decimal point is ',' for example: 1,23 ?
zh-CN_phoneb decimal point is '.' for example: ¥1.23
zh-CN_stroke decimal point is '.' for example: ¥1.23
zh-HK_radstr decimal point is '.' for example: HK$1.23
zh-MO_radstr decimal point is '.' for example: MOP1.23
zh-MO_stroke decimal point is '.' for example: MOP1.23
zh-SG_phoneb decimal point is '.' for example: $1.23
zh-SG_stroke decimal point is '.' for example: $1.23
zh-TW_pronun decimal point is '.' for example: NT$1.23
zh-TW_radstr decimal point is '.' for example: NT$1.23