12
votes

The Java class java.util.Locale has a set of public static final fields for languages/countries for direct references to specific locales. Other locales can easily be used via the appropriate constructors.

However, the selection of values seems rather arbitrary to me.

The languages are (in the order in which they appear in the source): English, French, German, Italian, Japanese, Korean, Chinese, Simplified Chinese, Traditional Chinese

The countries are: France, Germany, Italy, Japan, Korea, China, PRC, Taiwan, UK, US, Canda and Canada French (for the locale fr_CA).

Does anyone have an idea (or even a guess) how those languages/countries where chosen?

3
I don't know but one stupid thing I found out today is that there is a constant named Locale.UK but UK is not a valid country code - the corresponding country code is GB...Jesper

3 Answers

11
votes

Those codes are defined by ISO standards 3166 for country codes and 639 for language codes. See also the W3C Internationalization Activity page.

Edit:

Re-reading the question, the OP already knew this :-)

According to the Sun article Internationalization: Understanding Locale in the Java Platform those values are chosen as examples and it even tells us:

Because so few premade locales exist, you should probably just avoid these static objects altogether.

4
votes

I'd guess it's simply the most often used locales as a convenience for developers.

From the Javadoc:

The Locale class provides a number of convenient constants that you can use to create Locale objects for commonly used locales.

0
votes

My guess is that they use their Tier 1 languages - the ones that JRE is localized to. As for countries, I think they simply match it with languages. Well, we probably will never know unless somebody involved speak up.