命名空间
变体
操作

LC_ALL, LC_COLLATE, LC_CTYPE, LC_MONETARY, LC_NUMERIC, LC_TIME

来自 cppreference.cn
< cpp‎ | locale
 
 
 
 
定义于头文件 <clocale>
#define LC_ALL      /* 实现定义 */
#define LC_COLLATE  /* 实现定义 */
#define LC_CTYPE    /* 实现定义 */
#define LC_MONETARY /* 实现定义 */
#define LC_NUMERIC  /* 实现定义 */
#define LC_TIME     /* 实现定义 */

以上每个宏常量都展开为具有不同值的整数常量表达式,适用于用作 std::setlocale 的第一个参数。

常量 解释
LC_ALL 选择整个 C 区域设置
LC_COLLATE 选择 C 区域设置的排序规则类别
LC_CTYPE 选择 C 区域设置的字符分类类别
LC_MONETARY 选择 C 区域设置的货币格式化类别
LC_NUMERIC 选择 C 区域设置的数值格式化类别
LC_TIME 选择 C 区域设置的时间格式化类别

其他宏常量,名称以 LC_ 开头,后跟至少一个大写字母,可以在 <clocale> 中定义。 例如,POSIX 规范要求 LC_MESSAGES(控制 std::perrorstd::strerror),ISO/IEC 30112:2014 (2014 草案) 另外定义了 LC_IDENTIFICATIONLC_XLITERATELC_NAMELC_ADDRESSLC_TELEPHONELC_PAPERLC_MEASUREMENTLC_KEYBOARD,这些都受 GNU C 库支持(LC_XLITERATE 除外)。

[编辑] 示例

#include <clocale>
#include <cstdio>
#include <ctime>
#include <cwchar>
 
int main()
{
    // the C locale will be the UTF-8 enabled English:
    std::setlocale(LC_ALL, "en_US.UTF-8");
 
    // decimal dot will be German:
    std::setlocale(LC_NUMERIC, "de_DE.UTF-8");
 
    // date/time formatting will be Japanese:
    std::setlocale(LC_TIME, "ja_JP.UTF-8");
 
    wchar_t str[100];
    std::time_t t = std::time(nullptr);
    std::wcsftime(str, 100, L"%A %c", std::localtime(&t));
    std::wprintf(L"Number: %.2f\nDate: %Ls\n", 3.14, str);
}

输出

Number: 3,14
Date: 日曜日 2022年11月06日 17時55分10秒

[编辑] 参见

获取和设置当前的 C 区域设置
(函数) [编辑]
封装文化差异的多态 facet 集合
(类) [编辑]
C 文档 关于 区域设置类别