10.3 Sprachen der Länder
 
Programme der ersten Generation konnten nur mit fest verdrahteten Landessprachen und landesüblichen Bezeichnungen umgehen. Daraus ergaben sich natürlich vielfältige Probleme. Mehrsprachige Programme mussten aufwendig entwickelt werden, damit sie unter mehreren Sprachen lokalisierte Ausgaben liefern. (Es ergaben sich bereits Probleme dadurch, dass unterschiedliche Zeichenkodierungen verwendet wurden. Dies wurde aber mit Unicode umgangen.) Es blieb das Problem, dass sprachabhängige Zeichenketten, wie alle anderen Zeichenketten auch, überall im Programmtext verteilt sind. Eine nachträgliche Sprachanpassung wird schwer. Java bietet hier eine Lösung an: zum einen durch die Definition einer Sprache und damit automatische Formatierungen, und zum anderen durch die Möglichkeit, sprachenabhängige Teile in Ressourcen-Dateien auszulagern.

Eclipse kann automatisch die Zeichenketten eines Programms in eine Datei auszulagern. Dazu ist im Menü "Source" der Eintrag "Externalize Strings…" aufzurufen.
10.3.1 Sprachen und Regionen über Locale-Objekte
 
In Java repräsentieren Locale-Objekte geografische, politische oder kulturelle Regionen. Die Sprache und die Region müssen getrennt werden, denn nicht immer gibt eine Region oder ein Land die Sprache eindeutig vor. Für Kanada in der Umgebung von Quebec ist die französische Ausgabe relevant, und die unterscheidet sich von der englischen. Jede dieser sprachspezifischen Eigenschaften ist in einem speziellen Objekt gekapselt.
Beispiel Sprach-Objekte werden immer mit dem Namen der Sprache und optional mit dem Namen des Landes beziehungsweise einer Region erzeugt. Im Konstruktor der Klasse Locale werden dann Länderabkürzungen angegeben, etwa für ein Sprach-Objekt für England oder Frankreich.
Locale greatBritain = new Locale( "en", "GB" );
Locale french = new Locale( "fr" );
Im zweiten Beispiel ist uns das Land egal. Wir haben einfach nur die Sprache Französisch ausgewählt, egal in welchem Teil der Welt.
|
Die Sprachen sind durch Zwei-Buchstaben-Kürzel aus dem ISO 639-Code1
(ISO Language Code) identifiziert, und die Ländernamen sind Zwei-Buchstaben-Kürzel, die in ISO 31662
(ISO Country Code) beschrieben sind.
final class java.util. Locale
implements Cloneable, Serializable
|
|
Locale( String language )
Erzeugt ein neues Locale-Objekt für die Sprache language nach dem ISO 693-Standard. |
|
Locale( String language, String country )
Erzeugt ein Locale-Objekt für language (ISO 693) und das Land country nach dem ISO 3166-Standard. |
|
public Locale( String language, String country, String variant )
Erzeugt ein Locale-Objekt für language und das Land country in der Variante variant. variant ist eine herstellerabhängige Angabe, wie WIN oder MAC. |
Konstanten für einige Länder
Die Locale-Klasse besitzt Konstanten für häufig auftretende Länder und Sprachen. Für ein Locale-Objekt für Great Britain kann anstelle von new Locale("en","GB") auch Locale.UK Verwendung finden. Unter den Konstanten sind: CANADA, CANADA_FRENCH, CHINA, CHINESE, ENGLISH, FRANCE, FRENCH, GERMAN, GERMANY, ITALIAN, ITALY, JAPAN, JAPANESE, KOREA, KOREAN, PRC, SIMPLIFIED_CHINESE, TAIWAN, TRADITIONAL_CHINESE, UK und US. Im Quellcode der Klasse Locale sind dazu einfach die entsprechenden Länderkürzel als Namen von Konstanten definiert.
Zwei Beispiele:
static public final Locale FRANCE = new Locale("fr","FR","");
static public final Locale GERMANY = new Locale("de","DE","");
Methoden von Locale
Locale-Objekte lassen sich fragen, wie ihre Sprache heißt, die sie repräsentieren. Dazu bietet das Locale-Objekt eine Reihe von Methoden an:
final class java.util. Locale
implements Cloneable, Serializable
|
|
String getCountry()
Liefert das Länderkürzel nach dem ISO-3166-Zwei-Buchstaben-Code. |
|
String getLanguage()
Liefert das Kürzel der Sprache im ISO-639-Code. |
|
String getVariant()
Liefert das Kürzel der Variante. |
|
final String getDisplayCountry()
Liefert ein Kürzel des Landes für Bildschirmausgaben. |
|
final String getDisplayLanguage()
Liefert ein Kürzel der Sprache für Bildschirmausgaben. |
|
final String getDisplayName()
Liefert den Namen der Einstellungen. |
|
final String getDisplayVariant()
Liefert den Namen der Variante. |
|
String getISO3Country()
Liefert die ISO-Abkürzung des Landes dieser Einstellungen und löst eine MissingResourceException aus, wenn die ISO-Abkürzung nicht verfügbar ist. |
|
String getISO3Language()
Liefert die ISO-Abkürzung der Sprache dieser Einstellungen und löst eine MissingResourceException aus, wenn die ISO-Abkürzung nicht verfügbar ist. |
Beispiel Die folgende Applikation gibt alle gefundenen Locale-Objekte aus (über 130). An der Ausgabe sind die Unterschiede der Funktionen gut zu erkennen.
|
Listing 10.1
AllLocales.java
import java.util.Locale;
import static java.lang.System.out;
public class AllLocales
{
public static void main( String[] args )
{
for ( Locale l : Locale.getAvailableLocales() )
{ // Beispiel für Deutschland
out.print( l.getCountry() + ", " ); // DE
out.print( l.getLanguage() + ", " ); // de
out.print( l.getVariant() + ", " ); //
out.print( l.getDisplayName() + ", " ); // Deutsch (Deutschland)
out.print( l.getDisplayCountry() + ", " ); // Deutschland
out.print( l.getDisplayLanguage() + ", " );// Deutsch
out.print( l.getDisplayName() + ", " ); // Deutsch (Deutschland)
out.print( l.getDisplayVariant() + ", " ); //
out.print( l.getISO3Country() + ", " ); // DEU
out.println( l.getISO3Language() ); // deu
}
}
}
Ein Ausschnitt der Ausgabe. Bemerkenswert ist, dass einige Angaben nicht gefüllt sind.
, ar, , Arabisch, , Arabisch, Arabisch, , , ara
AE, ar, , Arabisch (Vereinigte Arabische Emirate), Vereinigte Arabische Emirate, Arabisch, Arabisch
(Vereinigte Arabische Emirate), , ARE, ara
BH, ar, , Arabisch (Bahrain), Bahrain, Arabisch, Arabisch (Bahrain), , BHR, ara
DZ, ar, , Arabisch (Algerien), Algerien, Arabisch, Arabisch (Algerien), , DZA, ara
EG, ar, , Arabisch (Ägypten), Ägypten, Arabisch, Arabisch (Ägypten), , EGY, ara
IQ, ar, , Arabisch (Irak), Irak, Arabisch, Arabisch (Irak), , IRQ, ara
...
, sv, , Schwedisch, , Schwedisch, Schwedisch, , , swe
SE, sv, , Schwedisch (Schweden), Schweden, Schwedisch, Schwedisch (Schweden), , SWE, swe
, tr, , Türkisch, , Türkisch, Türkisch, , , tur
TR, tr, , Türkisch (Türkei), Türkei, Türkisch, Türkisch (Türkei), , TUR, tur
, uk, , Ukrainisch, , Ukrainisch, Ukrainisch, , , ukr
UA, uk, , Ukrainisch (Ukraine), Ukraine, Ukrainisch, Ukrainisch (Ukraine), , UKR, ukr
US, en, , Englisch (Vereinigte Staaten von Amerika), Vereinigte Staaten von Amerika, Englisch, Englisch
(Vereinigte Staaten von Amerika), , USA, eng
, en, , Englisch, , Englisch, Englisch, , , eng
 Hier klicken, um das Bild zu Vergrößern
1 http://www.loc.gov/standards/iso639-2/langcodes.html
2 http://userpage.chemie.fu-berlin.de/diverse/doc/ISO_3166.html
|