LC_ALL、LC_COLLATE、LC_CTYPE、LC_MONETARY、LC_NUMERIC、LC_TIME
来自 cppreference.com
定义在头文件 <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
(它控制 perror 和 strerror 等),ISO/IEC 30112:2014 (2014 草案) 还定义了 LC_IDENTIFICATION
、LC_XLITERATE
、LC_NAME
、LC_ADDRESS
、LC_TELEPHONE
、LC_PAPER
、LC_MEASUREMENT
和 LC_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 区域设置类别
|