C 標準庫 - <locale.h>
簡介
locale.h 頭檔定義了特定地域的設置,比如日期格式和貨幣符號。接下來我們將介紹一些宏,以及一個重要的結構 struct lconv 和兩個重要的函數。
庫宏
下麵列出了頭檔 locale.h 中定義的宏,這些宏將在下列的兩個函數中使用:
| 序號 | 宏 & 描述 |
|---|---|
| 1 | LC_ALL 設置下麵的所有選項。 |
| 2 | LC_COLLATE 影響 strcoll 和 strxfrm 函數。 |
| 3 | LC_CTYPE 影響所有字元函數。 |
| 4 | LC_MONETARY 影響 localeconv 函數提供的貨幣資訊。 |
| 5 | LC_NUMERIC 影響 localeconv 函數提供的小數點格式化和資訊。 |
| 6 | LC_TIME 影響 strftime 函數。 |
庫函數
下麵列出了頭檔 locale.h 中定義的函數:
| 序號 | 函數 & 描述 |
|---|---|
| 1 | char *setlocale(int category, const char *locale) 設置或讀取地域化資訊。 |
| 2 | struct lconv *localeconv(void) 設置或讀取地域化資訊。 |
庫結構
typedef struct {
char *decimal_point;
char *thousands_sep;
char *grouping;
char *int_curr_symbol;
char *currency_symbol;
char *mon_decimal_point;
char *mon_thousands_sep;
char *mon_grouping;
char *positive_sign;
char *negative_sign;
char int_frac_digits;
char frac_digits;
char p_cs_precedes;
char p_sep_by_space;
char n_cs_precedes;
char n_sep_by_space;
char p_sign_posn;
char n_sign_posn;
} lconv
以下是各字段的描述:
| 序號 | 字段 & 描述 |
|---|---|
| 1 | decimal_point 用於非貨幣值的小數點字元。 |
| 2 | thousands_sep 用於非貨幣值的千位分隔符號。 |
| 3 | grouping 一個表示非貨幣量中每組數字大小的字串。每個字元代表一個整數值,每個整數指定當前組的位數。值為 0 意味著前一個值將應用於剩餘的分組。 |
| 4 | int_curr_symbol 國際貨幣符號使用的字串。前三個字元是由 ISO 4217:1987 指定的,第四個字元用於分隔貨幣符號和貨幣量。 |
| 5 | currency_symbol 用於貨幣的本地符號。 |
| 6 | mon_decimal_point 用於貨幣值的小數點字元。 |
| 7 | mon_thousands_sep 用於貨幣值的千位分隔符號。 |
| 8 | mon_grouping 一個表示貨幣值中每組數字大小的字串。每個字元代表一個整數值,每個整數指定當前組的位數。值為 0 意味著前一個值將應用於剩餘的分組。 |
| 9 | positive_sign 用於正貨幣值的字元。 |
| 10 | negative_sign 用於負貨幣值的字元。 |
| 11 | int_frac_digits 國際貨幣值中小數點後要顯示的位數。 |
| 12 | frac_digits 貨幣值中小數點後要顯示的位數。 |
| 13 | p_cs_precedes 如果等於 1,則 currency_symbol 出現在正貨幣值之前。如果等於 0,則 currency_symbol 出現在正貨幣值之後。 |
| 14 | p_sep_by_space 如果等於 1,則 currency_symbol 和正貨幣值之間使用空格分隔。如果等於 0,則 currency_symbol 和正貨幣值之間不使用空格分隔。 |
| 15 | n_cs_precedes 如果等於 1,則 currency_symbol 出現在負貨幣值之前。如果等於 0,則 currency_symbol 出現在負貨幣值之後。 |
| 16 | n_sep_by_space 如果等於 1,則 currency_symbol 和負貨幣值之間使用空格分隔。如果等於 0,則 currency_symbol 和負貨幣值之間不使用空格分隔。 |
| 17 | p_sign_posn 表示正貨幣值中正號的位置。 |
| 18 | n_sign_posn 表示負貨幣值中負號的位置。 |
下麵的值用於 p_sign_posn 和 n_sign_posn:
| 值 | 描述 |
|---|---|
| 0 | 封裝值和 currency_symbol 的括弧。 |
| 1 | 放置在值和 currency_symbol 之前的符號。 |
| 2 | 放置在值和 currency_symbol 之後的符號。 |
| 3 | 緊挨著放置在值和 currency_symbol 之前的符號。 |
| 4 | 緊挨著放置在值和 currency_symbol 之後的符號。 |
