ResourceBundle.Control Klasse

Definition

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

[Android.Runtime.Register("java/util/ResourceBundle$Control", DoNotGenerateAcw=true)]
public class ResourceBundle.Control : Java.Lang.Object
[<Android.Runtime.Register("java/util/ResourceBundle$Control", DoNotGenerateAcw=true)>]
type ResourceBundle.Control = class
    inherit Object
Vererbung
ResourceBundle.Control
Attribute

Hinweise

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden. Anders ausgedrückt: Ein ResourceBundle.Control arbeitet mit den Factorymethoden zum Laden von Ressourcenbündeln zusammen. Die Standardimplementierung der Rückrufmethoden stellt die Informationen bereit, die für die Factorymethoden erforderlich sind, um das Standardverhalten auszuführen.

Zusätzlich zu den Rückrufmethoden werden die #toBundleName(String, Locale) toBundleName Methoden und #toResourceName(String, String) toResourceName in erster Linie zur Vereinfachung bei der Implementierung der Rückrufmethoden definiert. Die -Methode kann jedoch überschrieben werden, toBundleName um unterschiedliche Konventionen in der organization und Verpackung lokalisierter Ressourcen bereitzustellen. Die toResourceName Methode besteht darin final , die Verwendung falscher Ressourcen- und Klassennamentrennzeichen zu vermeiden.

Zwei Factorymethoden und #getNoFallbackControl(List)stellen Instanzen bereitResourceBundle.Control, #getControl(List) die allgemeine Variationen des Standardpaketladeprozesses implementieren.

Die von der Methode zurückgegebenen Formate und von der Control#getFormats(String) getFormats Methode zurückgegebenen Gebietsschemas für Kandidaten ResourceBundle.Control#getCandidateLocales(String, Locale) getCandidateLocales müssen in allen ResourceBundle.getBundle Aufrufen für dasselbe Basispaket konsistent sein. Andernfalls können die ResourceBundle.getBundle Methoden unbeabsichtigte Bündel zurückgeben. Wenn beispielsweise nur "java.class" von der -Methode für den getFormats ersten Aufruf ResourceBundle.getBundle und nur "java.properties" für den zweiten Aufruf zurückgegeben wird, gibt der zweite Aufruf den klassenbasierten Aufruf zurück, der während des ersten Aufrufs zwischengespeichert wurde.

Ein ResourceBundle.Control instance muss threadsicher sein, wenn er gleichzeitig von mehreren Threads verwendet wird. ResourceBundle.getBundle wird nicht synchronisiert, um die ResourceBundle.Control Methoden aufzurufen. Die Standardimplementierungen der Methoden sind threadsicher.

Anwendungen können Instanzen angeben ResourceBundle.Control , die von den getControl Factorymethoden zurückgegeben oder aus einer Unterklasse von erstellt werden, um den Ladevorgang des ResourceBundle.Control Bundles anzupassen. Im Folgenden werden Beispiele für das Ändern des standardmäßigen Ladevorgangs für Bündel aufgeführt.

<b>Beispiel 1</b>

Mit dem folgenden Code können ResourceBundle.getBundle nur eigenschaftenbasierte Ressourcen gesucht werden.

import java.util.*;
            import static java.util.ResourceBundle.Control.*;
            ...
            ResourceBundle bundle =
              ResourceBundle.getBundle("MyResources", new Locale("fr", "CH"),
                                       ResourceBundle.Control.getControl(FORMAT_PROPERTIES));

Angesichts der Ressourcenbündel im Beispiel in der ResourceBundle.getBundle Beschreibung wird dieser ResourceBundle.getBundle Aufruf geladen MyResources_fr_CH.properties , dessen übergeordnetes Element das übergeordnete Element ist MyResources_fr.propertiesMyResources.properties. (MyResources_fr_CH.properties ist nicht ausgeblendet, aber MyResources_fr_CH.class ist.)

<b>Beispiel 2</b>

Im Folgenden finden Sie ein Beispiel für das Laden von XML-basierten Bundles mit Properties#loadFromXML(java.io.InputStream) Properties.loadFromXML.

ResourceBundle rb = ResourceBundle.getBundle("Messages",
                new ResourceBundle.Control() {
                    public List&lt;String&gt; getFormats(String baseName) {
                        if (baseName == null)
                            throw new NullPointerException();
                        return Arrays.asList("xml");
                    }
                    public ResourceBundle newBundle(String baseName,
                                                    Locale locale,
                                                    String format,
                                                    ClassLoader loader,
                                                    boolean reload)
                                     throws IllegalAccessException,
                                            InstantiationException,
                                            IOException {
                        if (baseName == null || locale == null
                              || format == null || loader == null)
                            throw new NullPointerException();
                        ResourceBundle bundle = null;
                        if (format.equals("xml")) {
                            String bundleName = toBundleName(baseName, locale);
                            String resourceName = toResourceName(bundleName, format);
                            InputStream stream = null;
                            if (reload) {
                                URL url = loader.getResource(resourceName);
                                if (url != null) {
                                    URLConnection connection = url.openConnection();
                                    if (connection != null) {
                                        // Disable caches to get fresh data for
                                        // reloading.
                                        connection.setUseCaches(false);
                                        stream = connection.getInputStream();
                                    }
                                }
                            } else {
                                stream = loader.getResourceAsStream(resourceName);
                            }
                            if (stream != null) {
                                BufferedInputStream bis = new BufferedInputStream(stream);
                                bundle = new XMLResourceBundle(bis);
                                bis.close();
                            }
                        }
                        return bundle;
                    }
                });

            ...

            private static class XMLResourceBundle extends ResourceBundle {
                private Properties props;
                XMLResourceBundle(InputStream stream) throws IOException {
                    props = new Properties();
                    props.loadFromXML(stream);
                }
                protected Object handleGetObject(String key) {
                    return props.getProperty(key);
                }
                public Enumeration&lt;String&gt; getKeys() {
                    ...
                }
            }

In Version 1.6 hinzugefügt.

Java-Dokumentation für java.util.ResourceBundle.Control.

Teile dieser Seite sind Änderungen, die auf Arbeiten basieren, die vom Android Open Source Project erstellt und freigegeben wurden und gemäß den In Attribution License beschriebenen Begriffen verwendet werden.

Konstruktoren

ResourceBundle.Control()

Einziger Konstruktor.

ResourceBundle.Control(IntPtr, JniHandleOwnership)

Ein Konstruktor, der beim Erstellen verwalteter Darstellungen von JNI-Objekten verwendet wird; wird von der Runtime aufgerufen.

Felder

TtlDontCache

Die Time-to-Live-Konstante für geladene Ressourcenpaketinstanzen, die nicht zwischengespeichert werden.

TtlNoExpirationControl

Die Time-to-Live-Konstante zum Deaktivieren der Ablaufsteuerung für geladene Ressourcenpaketinstanzen im Cache.

Eigenschaften

Class

Gibt die Laufzeitklasse dieses Objectzurück.

(Geerbt von Object)
FormatClass

Das Klassenformat List , das enthält "java.class".

FormatDefault

Das Standardformat List, das die Zeichenfolgen "java.class" und enthält "java.properties", in dieser Reihenfolge.

FormatProperties

Das Nur-Eigenschaftenformat List , das enthält "java.properties".

Handle

Das Handle für die zugrunde liegende Android-instance.

(Geerbt von Object)
JniIdentityHashCode

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
JniPeerMembers

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

PeerReference

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
ThresholdClass

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

ThresholdType

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

Methoden

Clone()

Erstellt und gibt eine Kopie dieses Objekts zurück.

(Geerbt von Object)
Dispose()

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
Dispose(Boolean)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
Equals(Object)

Gibt an, ob ein anderes Objekt "gleich" diesem objekt ist.

(Geerbt von Object)
GetCandidateLocales(String, Locale)

Gibt einen List von Locales als Kandidatengebietsschemas für baseName und zurück locale.

GetControl(IList<String>)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

GetFallbackLocale(String, Locale)

Gibt einen Locale zurück, der als Fallbackgebietsschema für weitere Ressourcenbündelsuchen durch die ResourceBundle.getBundle Factorymethode verwendet werden soll.

GetFormats(String)

Gibt eine List von Strings zurück, die Formate enthält, die zum Laden von Ressourcenbündeln für das angegebene baseNameverwendet werden sollen.

GetHashCode()

Gibt einen Hashcodewert für das Objekt zurück.

(Geerbt von Object)
GetNoFallbackControl(IList<String>)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

GetTimeToLive(String, Locale)

Gibt den Wert für die Gültigkeitsdauer (Time-to-Live, TTL) für Ressourcenbündel zurück, die unter dieser ResourceBundle.Controlgeladen werden.

JavaFinalize()

Wird vom Garbage Collector für ein Objekt aufgerufen, wenn die Garbage Collection feststellt, dass keine Verweise mehr auf das Objekt vorhanden sind.

(Geerbt von Object)
NeedsReload(String, Locale, String, ClassLoader, ResourceBundle, Int64)

Bestimmt, ob das bundle abgelaufene im Cache neu geladen werden muss, basierend auf der von loadTime oder einigen anderen Kriterien angegebenen Ladezeit.

NewBundle(String, Locale, String, ClassLoader, Boolean)

Instanziiert ein Ressourcenpaket für den angegebenen Paketnamen des angegebenen Formats und Gebietsschemas, wobei bei Bedarf das angegebene Klassenladeprogramm verwendet wird.

Notify()

Aktiviert einen einzelnen Thread, der auf den Monitor dieses Objekts wartet.

(Geerbt von Object)
NotifyAll()

Aktiviert alle Threads, die auf den Monitor dieses Objekts warten.

(Geerbt von Object)
SetHandle(IntPtr, JniHandleOwnership)

Legt die Handle-Eigenschaft fest.

(Geerbt von Object)
ToArray<T>()

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
ToBundleName(String, Locale)

Konvertiert das angegebene baseName und locale in den Bundlenamen.

ToResourceName(String, String)

Konvertiert das angegebene bundleName in das von der ClassLoader#getResource ClassLoader.getResource -Methode erforderliche Formular, indem alle Vorkommen von '.' in bundleName durch '/' und angefügt werden und '.' die angegebene Datei suffix.

ToString()

Gibt eine Zeichenfolgendarstellung des Objekts zurück.

(Geerbt von Object)
UnregisterFromRuntime()

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
Wait()

Bewirkt, dass der aktuelle Thread wartet, bis er aktiviert ist, in der Regel durch <>Benachrichtigung</em> oder <em>interrupted</em>.

(Geerbt von Object)
Wait(Int64)

Bewirkt, dass der aktuelle Thread wartet, bis er aktiviert ist, in der Regel durch>< Benachrichtigung</em> oder <em>interrupted</em>, oder bis eine bestimmte Menge an Echtzeit verstrichen ist.

(Geerbt von Object)
Wait(Int64, Int32)

Bewirkt, dass der aktuelle Thread wartet, bis er aktiviert ist, in der Regel durch>< Benachrichtigung</em> oder <em>interrupted</em>, oder bis eine bestimmte Menge an Echtzeit verstrichen ist.

(Geerbt von Object)

Explizite Schnittstellenimplementierungen

IJavaPeerable.Disposed()

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
IJavaPeerable.DisposeUnlessReferenced()

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
IJavaPeerable.Finalized()

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
IJavaPeerable.JniManagedPeerState

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

(Geerbt von Object)

Erweiterungsmethoden

JavaCast<TResult>(IJavaObject)

Führt eine Typkonvertierung mit Überprüfung der Android-Laufzeit aus.

JavaCast<TResult>(IJavaObject)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

GetJniTypeName(IJavaPeerable)

ResourceBundle.Control definiert eine Reihe von Rückrufmethoden, die von den ResourceBundle#getBundle(String, Locale, ClassLoader, Control) ResourceBundle.getBundle Factorymethoden während des Ladevorgangs des Bundles aufgerufen werden.

Gilt für: