命名空间
变体
操作

LC_ALL、LC_COLLATE、LC_CTYPE、LC_MONETARY、LC_NUMERIC、LC_TIME

来自 cppreference.com
< c‎ | locale
定义在头文件 <locale.h>
#define LC_ALL      /*实现定义*/
#define LC_COLLATE  /*实现定义*/
#define LC_CTYPE    /*实现定义*/
#define LC_MONETARY /*实现定义*/
#define LC_NUMERIC  /*实现定义*/
#define LC_TIME     /*实现定义*/

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

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

locale.h 中可能定义了其他宏常量,其名称以 LC_ 后跟至少一个大写字母开头。例如,POSIX 规范要求使用 LC_MESSAGES(它控制 perrorstrerror 等),ISO/IEC 30112:2014 (2014 草案) 还定义了 LC_IDENTIFICATIONLC_XLITERATELC_NAMELC_ADDRESSLC_TELEPHONELC_PAPERLC_MEASUREMENTLC_KEYBOARD,这些由 GNU C 库支持(除了 LC_XLITERATE)。

[编辑] 示例

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

可能的输出

Number: 3,14
Date: 金曜日 2023年09月15日 20時04分14秒

[编辑] 参考文献

  • C23 标准 (ISO/IEC 9899:2024)
  • 7.11/3 本地化 <locale.h> (p: 待定)
  • C17 标准 (ISO/IEC 9899:2018)
  • 7.11/3 本地化 <locale.h> (p: 待定)
  • C11 标准 (ISO/IEC 9899:2011)
  • 7.11/3 本地化 <locale.h> (p: 224)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.11/3 本地化 <locale.h> (p: 205)
  • C89/C90 标准 (ISO/IEC 9899:1990)
  • 4.4 本地化 <locale.h>

[编辑] 另请参阅

获取和设置当前 C 区域设置
(函数) [编辑]
C++ 文档 for 区域设置类别