Locale 是 Java 国际化的基石,用于标识用户所属地理文化区域及表达习惯,如日期、货币、数字格式和文字排序规则,不负责翻译且区别于时区与用户偏好源头。

Locale 类是 Java 国际化(i18n)的基石,它不负责翻译文字,而是告诉程序“用户来自哪里、习惯怎么表达”——比如日期怎么写、钱怎么标、数字怎么分组、文字怎么排序。
(Locale 是什么?)
它代表一个特定的地理、政治或文化区域,例如:
• Locale.US 表示美国英语环境(日期:12/24/2025,货币:$1,234.56)
• Locale.CHINA 表示中国大陆中文环境(日期:2025年12月24日,货币:¥1,234.56)
• new Locale("de", "CH") 表示瑞士德语区(货币符号是 CHF,千位分隔符用',',小数点用'.')
(Locale 怎么创建?)
推荐用标准方式,避免拼写错误:
• 直接使用内置常量:Locale.US、Locale.CHINA、Locale.JAPAN
• 用语言标签(RFC 5646 标准):Locale.forLanguageTag("zh-Hans-CN")(简体中文-中国大陆)
• 构造函数(慎用):new Locale("en", "GB") —— 语言代码必须小写,国家代码必须大写
• 灵活构建:new Locale.Builder().setLanguage("pt").setRegion("BR").build()
(Locale 最常用的三个场景)
• 加载多语言资源:配合 ResourceBundle 读取对应语言的 messages_zh_CN.properties 或 messages_en_US.properties
• 格式化数据:
– 货币:NumberFormat.getCurrencyInstance(locale).format(999.99)
– 日期:DateFormat.getDateInstance(DateFormat.LONG, locale).format(new Date())
– 数字:NumberFormat.getNumberInstance(locale).format(1234567)
• 语言敏感操作:比如字符串排序(Collator.getInstance(locale))、大小写转换("ß".toUpperCase(Locale.GERMAN) 得到 "SS")
(Locale 常见误区提醒)
• 它 ≠ 时区(TimeZone):Locale 不管时间偏移,只管“怎么表达”
• 它 ≠ 用户偏好设置源头:通常应从 HTTP 请求头(Accept-Language)、系统设置或用户显式选择中获取,而不是硬编码
• 不要直接修改默认 Locale:Locale.setDefault(...) 会影响整个 JVM,线程不安全,应优先按需传参使用










