Heim  >  Artikel  >  Java  >  Detaillierte Erläuterung von Vergleichsbeispielen für lokale ThreadLocal-Threads und Synchronisationsmechanismen in Java

Detaillierte Erläuterung von Vergleichsbeispielen für lokale ThreadLocal-Threads und Synchronisationsmechanismen in Java

黄舟
黄舟Original
2017-03-23 10:28:001824Durchsuche

In diesem Artikel werden hauptsächlich relevante Informationen zum Vergleich lokaler ThreadLocal-Threads und Synchronisierungsmechanismen in Java vorgestellt. Freunde in Not können sich auf

Das Design von ThreadLocal

beziehen

Werfen Sie zunächst einen Blick auf die Schnittstelle von ThreadLocal:

Object get() ; // 返回当前线程的线程局部变量副本 protected Object
initialValue(); // 返回该线程局部变量的当前线程的初始值          
void set(Object value); // 设置当前线程的线程局部变量副本的值

ThreadLocal verfügt über drei Methoden, von denen die bemerkenswerteste initialValue() ist, eine geschützte Methode, die offensichtlich speziell implementiert ist zum Überschreiben von Unterklassen. Diese Methode gibt den Anfangswert der lokalen Variablen des aktuellen Threads im Thread zurück. Diese Methode ist eine Methode mit verzögertem Aufruf, die ausgeführt wird, wenn ein Thread get() oder set(Object) zum ersten Mal aufruft, und nur einmal ausgeführt wird. Die eigentliche Implementierung in ThreadLocal gibt direkt einen null zurück:

protected Object initialValue() { return null; }

Wie verwaltet ThreadLocal eine Kopie der Variablen für jeden Thread? Tatsächlich ist die Implementierungsidee sehr einfach. In der ThreadLocal-Klasse gibt es eine Map, die zum Speichern einer Kopie der Variablen jedes Threads verwendet wird.

Zum Beispiel die folgende Beispielimplementierung: Sie entspricht dem Speichern einer Map. Dies ist die Implementierung der get-Methode von ThreadLocal >Vergleich von ThreadLocal und anderen Synchronisationsmechanismen

public T get() {
    Thread t = Thread.currentThread();//获取当前线程
    ThreadLocalMap map = getMap(t);
    if (map != null) {
      ThreadLocalMap.Entry e = map.getEntry(this);
      if (e != null)
        return (T)e.value;
    }
    return setInitialValue();
  }
  
  
   ThreadLocalMap getMap(Thread t) {
    return t.threadLocals;
  }

Welche Vorteile hat ThreadLocal im Vergleich zu anderen Synchronisationsmechanismen? ThreadLocal und alle anderen Synchronisationsmechanismen sind darauf ausgelegt, Zugriffskonflikte auf dieselbe Variable in mehreren Threads zu lösen. Bei gewöhnlichen Synchronisationsmechanismen wird Objektsperre verwendet, um einen sicheren Zugriff auf dieselbe Variable durch mehrere Threads zu erreichen. Zu diesem Zeitpunkt wird die Variable von mehreren Threads gemeinsam genutzt. Die Verwendung dieses Synchronisierungsmechanismus erfordert eine sehr detaillierte Analyse, wann die Variable gelesen und geschrieben werden soll, wann ein Objekt gesperrt werden soll, wann die Sperre des Objekts aufgehoben werden soll usw. All dies wird dadurch verursacht, dass mehrere Threads Ressourcen gemeinsam nutzen. ThreadLocal löst den gleichzeitigen Zugriff mehrerer Threads aus einem anderen Blickwinkel. ThreadLocal verwaltet eine Kopie der an den Thread gebundenen Variablen und isoliert so die Daten mehrerer Threads Es ist nicht erforderlich, die Variable zu synchronisieren. ThreadLocal stellt ein threadsicheres gemeinsames Objekt bereit. Beim Schreiben von Multithread-Code können Sie die gesamte unsichere Variable in ThreadLocal kapseln oder den threadspezifischen Zustand des Objekts in ThreadLocal kapseln.
Da ThreadLocal Objekte jeden Typs enthalten kann, erfordert die Verwendung von ThreadLocal zum Abrufen des Werts des aktuellen Threads eine erzwungene

Typkonvertierung

. Aber mit der Einführung von Vorlagen in der neuen Java-Version (1.5) wird die neue ThreadLocal8742468051c85b06f0a0af9e3e506b5c-Klasse, die Vorlagenparameter unterstützt, davon profitieren. Es ist auch möglich, die erzwungene Typkonvertierung zu reduzieren und einige Fehlerprüfungen auf die Kompilierungszeit vorzuziehen, was die Verwendung von ThreadLocal bis zu einem gewissen Grad vereinfacht.

Zusammenfassung

Natürlich kann ThreadLocal den Synchronisationsmechanismus nicht ersetzen, und die beiden Problembereiche sind unterschiedlich. Der Synchronisierungsmechanismus dient dazu, den gleichzeitigen Zugriff mehrerer Threads auf dieselben Ressourcen zu synchronisieren und stellt eine effektive Möglichkeit zur Kommunikation zwischen mehreren Threads dar. ThreadLocal dient dazu, die gemeinsame Nutzung von Daten durch mehrere Threads zu isolieren. Daher ist es natürlich nicht erforderlich, mehrere Threads zu synchronisieren. Wenn Sie daher zwischen mehreren Threads kommunizieren müssen, verwenden Sie den Synchronisierungsmechanismus. Wenn Sie Freigabekonflikte zwischen mehreren Threads isolieren müssen, können Sie ThreadLocal verwenden, wodurch Ihr Programm erheblich vereinfacht und lesbarer und prägnanter wird.

Häufige Verwendungen von ThreadLocal:


Speichern Sie den aktuellen Sitzungsbenutzer
Speichern Sie einige Kontextvariablen, z. B. den ActionContext von Webwork
Speichersitzungen, wie z. B. die Sitzung des Spring Hibernate Orms " (Singletons) ) oder ein Thread-sicheres gemeinsames Objekt, entweder durch Einkapseln der gesamten unsicheren Variablen in ein ThreadLocal oder durch Einkapseln des threadspezifischen Zustands des Objekts in ein ThreadLocal. Beispielsweise müssen in einer Anwendung, die eng mit einer Datenbank verknüpft ist, möglicherweise viele Methoden des Programms auf die Datenbank zugreifen. Es ist unpraktisch, eine Verbindung als Parameter in jede Methode des Systems aufzunehmen – der Zugriff auf die Verbindung über eine „Monade“ ist wahrscheinlich eine gröbere, aber viel bequemere Technik. Allerdings können mehrere Threads eine JDBC-Verbindung nicht sicher gemeinsam nutzen. Wie in Listing 3 gezeigt, können wir es durch die Verwendung von ThreadLocal in einer „Monade“ jeder Klasse in unserem Programm leicht machen, einen Verweis auf eine Verbindung pro Thread zu erhalten. Auf diese Weise können wir uns ThreadLocal so vorstellen, dass es uns ermöglicht, Monaden pro Thread zu erstellen.

Eine einfache Möglichkeit, die Thread-Sicherheit einer MySQL-Verbindung zu erreichen

Theoretisch ist ThreadLocal tatsächlich relativ zu jedem Thread, und jeder Thread hat seinen eigenen ThreadLocal. Aber wie oben erwähnt, verwalten allgemeine Anwendungsserver einen Thread-Pool. Daher können verschiedene Benutzer beim Zugriff denselben Thread erhalten. Wenn Sie also auf TheadLocal basieren, müssen Sie darauf achten, den Cache von ThreadLocal-Variablen zu vermeiden, was dazu führt, dass andere Threads auf die Variablen dieses Threads zugreifen.

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung von Vergleichsbeispielen für lokale ThreadLocal-Threads und Synchronisationsmechanismen in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn