地區設定名稱、語言和國家/地區字串
setlocale 和 _create_locale 函式的 locale 的引數,可使用 Windows NLS API 支援的地區設定名稱、語言、國家/地區碼和字碼頁來設定。 locale 引數有下列形式:
locale :: "locale_name"
| "language[_country_region[.code_page]]"
| ".code_page"
| "C"
| ""
| NULL
慣用的地區設定名稱格式如以 en-US 表示英文 (美國),或以 bs-Cyrl-BA 表示波士尼亞文 (斯拉夫,波士尼亞赫塞哥維納)。 地區設定名稱中描述的一組地區設定名稱。 如需 Windows 作業系統版本所支援的地區設定清單,請參閱國家語言支援 (NLS) API 參考的 [文化特性名稱] 一欄。 這項資源列出所支援的語言、指令碼和地區部分的地區設定名稱。 如需有關具有非預設排序次序之受支援地區設定名稱的詳細資訊,請參閱排序次序識別項中 [地區設定名稱] 一欄。
當使用語言字串或語言字串和國家/地區字串建立地區設定時,language[_country_region[.code_page]] 格式會儲存在分類的地區設定中。 語言字串 中描述的一組受支援語言字串,以及 國家/地區字串 所列的受支援國家/地區字串清單。 如果指定的語言和指定的國家/地區沒有關聯,則指定的國家/地區的預設語言會儲存在地區設定中。 我們不建議內嵌於程式碼或對儲存體序列化的地區設定字串使用此格式,因為這些字串比地區設定名稱格式更容易被作業系統更新變更。
字碼頁是與地區設定相關聯的 ANSI/OEM 字碼頁。 當您以語言或是以語言和國家/地區指定地區設定時,便會為您判定字碼頁。 特殊值 .ACP 會指定國家/地區的 ANSI 字碼頁。 特殊值 .OCP 會指定國家/地區的 OEM 字碼頁。 例如,如果您指定 「Greek_Greece.ACP」 做為地區設定,地區設定便會儲存為 Greek_Greece.1253 (希臘文的 ANSI 字碼頁)。如果您指定 「Greek_Greece.OCP」 做為地區設定,則會儲存為 Greek_Greece.737 (希臘文的 OEM 字碼頁)。 如需字碼頁的詳細資訊,請參閱 字碼頁。 如需 Windows 上受支援字碼頁的清單,請參閱字碼頁識別項。
如果您只使用字碼頁指定地區設定,則會使用系統預設的語言和國家/地區。 例如,如果您指定 " .1254 " (ANSI 土耳其文) 做為配置英文 (美國) 系統的地區設定,儲存的地區設定便是 English_United States.1254。 因為這可能會導致不一致的行為,所以不建議使用這個格式。
C 的 locale 值會指定符合 C 轉譯環境的最小 ANSI。 C 地區設定會假設每個 char 資料類型都是 1 位元組,而其值永遠小於 256。 如果 locale 指向空字串,地區設定即是由實作環境決定的原生環境。
藉由使用 LC_ALL 分類,可以為 setlocale 和 _wsetlocale 函式同時指定所有地區設定分類。 藉由使用具有此格式的地區設定引數,您可以將分類全設定為相同的地區設定,或是為每個分類個別設定:
LC_ALL_specifier :: locale
| [LC_COLLATE=locale][;LC_CTYPE=locale][;LC_MONETARY=locale][;LC_NUMERIC=locale][;LC_TIME=locale]
您可以指定多個分類類型,並以分號隔開。 未指定的分類類型會使用目前的地區設定。 例如,這個程式碼會將所有分類的目前地區設定設為 de-DE,然後將分類 LC_MONETARY 設為 en-GB,將 LC_TIME 設為 es-ES:
_wsetlocale(LC_ALL, L"de-DE");
_wsetlocale(LC_ALL, L"LC_MONETARY=en-GB;LC_TIME=es-ES");
請參閱
參考
_create_locale、_wcreate_locale