Locale with any combination of valid
language and country codes, but that doesn't mean that you can use it.
Remember, a Locale object is only an identifier. You pass
the Locale object to other objects, which then do the
real work. These other objects, which we call locale-sensitive, do not
know how to deal with all possible Locale definitions.
To find out which types of Locale definitions a
locale-sensitive class recognizes, you invoke the
getAvailableLocales method. For example, to find out which
Locale definitions are supported by the
DateFormat class, you could write a routine such as the
following:
import java.util.*;
import java.text.*;
public class Available {
static public void main(String[] args) {
Locale list[] = DateFormat.getAvailableLocales();
for (Locale aLocale : list) {
System.out.println(aLocale.toString());
}
}
}
Note that the
String returned by toString contains the
language and country codes, separated by an underscore:
ar_EG be_BY bg_BG ca_ES cs_CZ da_DK de_DE . . .
If you want to display a list of Locale names to end
users, you should show them something easier to understand than the
language and country codes returned by toString. Instead
you can invoke the Locale.getDisplayName method, which
retrieves a localized String of a Locale
object. For example, when toString is replaced by
getDisplayName in the preceding code, the program prints
the following lines:
Arabic (Egypt) Belarussian (Belarus) Bulgarian (Bulgaria) Catalan (Spain) Czech (Czech Republic) Danish (Denmark) German (Germany) . . .
You may see different locale lists depending on the Java Platform implementations.