LC_ALL, LC_COLLATE, LC_CTYPE, LC_MONETARY, LC_NUMERIC, LC_TIME
來自 cppreference.com
定義於標頭檔案 <locale.h> |
||
#define LC_ALL /* implementation-defined */ |
||
#define LC_COLLATE /* implementation-defined */ |
||
#define LC_CTYPE /* implementation-defined */ |
||
#define LC_MONETARY /* implementation-defined */ |
||
#define LC_NUMERIC /* implementation-defined */ |
||
#define LC_TIME /* implementation-defined */ |
||
上述每個宏常量都擴充套件為具有不同值的整數常量表達式,適合用作 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++ 文件,關於 區域設定類別
|