Freigeben über


Collections.SynchronizedSortedMap(IDictionary) Methode

Definition

Gibt eine synchronisierte (threadsicher) sortierte Zuordnung zurück, die von der angegebenen sortierten Zuordnung unterstützt wird.

[Android.Runtime.Register("synchronizedSortedMap", "(Ljava/util/SortedMap;)Ljava/util/SortedMap;", "")]
[Java.Interop.JavaTypeParameters(new System.String[] { "K", "V" })]
public static System.Collections.IDictionary SynchronizedSortedMap (System.Collections.IDictionary m);
[<Android.Runtime.Register("synchronizedSortedMap", "(Ljava/util/SortedMap;)Ljava/util/SortedMap;", "")>]
[<Java.Interop.JavaTypeParameters(new System.String[] { "K", "V" })>]
static member SynchronizedSortedMap : System.Collections.IDictionary -> System.Collections.IDictionary

Parameter

m
IDictionary

die sortierte Zuordnung, die in einer synchronisierten sortierten Karte "umbrochen" werden soll.

Gibt zurück

eine synchronisierte Ansicht der angegebenen sortierten Karte.

Attribute

Hinweise

Gibt eine synchronisierte (threadsicher) sortierte Zuordnung zurück, die von der angegebenen sortierten Zuordnung unterstützt wird. Um den seriellen Zugriff zu gewährleisten, ist es wichtig, dass <der starke>gesamte</starke> Zugriff auf die gesicherte sortierte Karte über die zurückgegebene sortierte Karte (oder deren Ansichten) erreicht wird.

Es ist zwingend erforderlich, dass der Benutzer manuell auf der zurückgegebenen sortierten Karte synchronisiert wird, wenn er eine seiner Sammlungsansichten durchläuft, oder die Auflistungsansichten eines seiner subMapAnsichten oder tailMap headMap Ansichten, über Iteratoroder Spliterator Stream:

SortedMap m = Collections.synchronizedSortedMap(new TreeMap());
                 ...
             Set s = m.keySet();  // Needn't be in synchronized block
                 ...
             synchronized (m) {  // Synchronizing on m, not s!
                 Iterator i = s.iterator(); // Must be in synchronized block
                 while (i.hasNext())
                     foo(i.next());
             }

oder:

SortedMap m = Collections.synchronizedSortedMap(new TreeMap());
             SortedMap m2 = m.subMap(foo, bar);
                 ...
             Set s2 = m2.keySet();  // Needn't be in synchronized block
                 ...
             synchronized (m) {  // Synchronizing on m, not m2 or s2!
                 Iterator i = s2.iterator(); // Must be in synchronized block
                 while (i.hasNext())
                     foo(i.next());
             }

Wenn dieser Rat nicht befolgt wird, kann dies zu einem nicht deterministischen Verhalten führen.

Die zurückgegebene sortierte Zuordnung kann serialisiert werden, wenn die angegebene sortierte Zuordnung serialisierbar ist.

Java-Dokumentation für java.util.Collections.synchronizedSortedMap(java.util.SortedMap<K, V>).

Teile dieser Seite sind Änderungen auf der Grundlage von Arbeiten, die vom Android Open Source-Projekt erstellt und freigegeben werden und gemäß den in der Creative Commons 2.5 Attribution License beschriebenen Begriffen verwendet werden.

Gilt für: