Heim >Java >JavaBase >Mehrere gängige Sperren in Java

Mehrere gängige Sperren in Java

王林
王林Original
2019-11-13 17:16:443743Durchsuche

Mehrere gängige Sperren in Java

1. Spin-Lock

Wie der Name schon sagt, wartet der Spin-Lock eine bestimmte Zeit (Spin) und nichts Wenn Sie dies nicht tun, müssen Sie nur warten, bis die Ressource freigegeben wird. Der Vorteil besteht darin, dass beim Umschalten zwischen Kernelmodus und Benutzermodus kein Effizienzverlust auftritt Die Ressource wird weiterhin die CPU-Ressource belegen, also eine Zeit lang durchlaufen und dann in den Blockierungszustand wechseln.

2. Heavyweight-Sperren

synchronisiert ist der Implementierungsmechanismus von Heavyweight-Sperren, die nicht auf Ressourcen zugreifen können.

3. Voreingenommene Sperre

Wie der Name schon sagt, wird der erste Prozess voreingenommen, um auf die Ressource zuzugreifen. Wenn nur ein Prozess den Synchronisationscodeblock ausführt, dann Die letzte Option ist die Bias-Sperre. Wenn andere Threads Ressourcen beanspruchen, wird sie auf eine leichte Sperre aktualisiert.

4. Leichtes Schloss

Nachdem das Bias-Schloss aufgerüstet wurde, wird es zu einem leichten Schloss. Das Schloss kann nur aufgerüstet, aber nicht herabgestuft werden. Andere Prozesse in der Lightweight-Sperre wechseln in den Selbstauswahlstatus. Wenn die Selbstauswahl fehlschlägt, wird die Heavyweight-Sperre aktualisiert.

5. Faire und unfaire Sperren

Bezieht sich hauptsächlich darauf, ob Threads zuerst kommen und zuerst bedient werden, um die Sperre zu erhalten, während ReentrantLock standardmäßig auf unfair gesetzt ist auf fair eingestellt sein.

6. Pessimistische Sperre

Gehen Sie immer vom schlimmsten Fall aus, wenn Sie die Daten erhalten, und denken Sie, dass andere sie ändern werden Es ist jederzeit gesperrt. Wenn also jemand anderes Daten abrufen möchte, werden sie blockiert, bis die Sperre erhalten wird (die gemeinsam genutzte Ressource wird jeweils nur von einem Thread verwendet, andere Threads werden blockiert und die Ressource wird blockiert). wird nach der Verwendung auf andere Threads übertragen).

Herkömmliche relationale Datenbanken verwenden viele solcher Sperrmechanismen, wie z. B. Zeilensperren, Tabellensperren, Lesesperren, Schreibsperren usw., die alle vor Operationen gesperrt werden. Exklusive Sperren wie synchronisiert und ReentrantLock in Java sind die Umsetzung der pessimistischen Sperridee.

7. Optimistisches Sperren

Gehen Sie immer von der besten Situation aus und denken Sie, dass andere sie nicht ändern werden Beim Aktualisieren wird jedoch beurteilt, ob andere die Daten in diesem Zeitraum aktualisiert haben. Dies kann mithilfe des Versionsnummernmechanismus (in der Datenbank) und des CAS-Algorithmus implementiert werden.

Empfohlenes Tutorial: Java-Tutorial

Das obige ist der detaillierte Inhalt vonMehrere gängige Sperren 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