Java-Interview – optimistisches Sperren und pessimistisches Sperren
Interviewfrage:
Der Unterschied zwischen optimistischem Sperren und pessimistischem Sperren
(Teilen von Lernvideos: Java-Lehrvideo)
1. Optimistisches Sperren
Ich denke immer, dass es keine Parallelitätsprobleme geben wird Jedes Mal, wenn ich Daten abrufe, wird immer davon ausgegangen, dass kein anderer Thread die Daten ändert, sodass sie nicht gesperrt werden. Beim Aktualisieren wird jedoch beurteilt, ob andere Threads die Daten zuvor geändert haben . Im Allgemeinen wird der Versionsnummernmechanismus oder die CAS-Operation verwendet, um dies zu erreichen Werden Daten geändert, wird der Versionswert um eins erhöht. Wenn Thread A den Datenwert aktualisieren möchte, liest er beim Einlesen der Daten auch den Versionswert. Aktualisieren Sie ihn beim Senden des Updates nur, wenn der gerade gelesene Versionswert mit dem Versionswert in der aktuellen Datenbank übereinstimmt. Andernfalls versuchen Sie es erneut . Update-Vorgang, bis das Update erfolgreich ist.
update table set x=x+1, version=version+1 where id=#{id} and version=#{version};
(Empfohlene Interviewfragen:
Java-Interviewfragen und -antworten)
CAS-Betriebsmethode: Das heißt, vergleichen und tauschen oder vergleichen und festlegen, unter Einbeziehung von drei Operanden, dem Speicherwert, in dem sich die Daten befinden, und dem erwarteten Wert Wert, neuer Wert. Wenn eine Aktualisierung erforderlich ist, wird beurteilt, ob der aktuelle Speicherwert mit dem zuvor erhaltenen Wert übereinstimmt. Wenn dies fehlschlägt, handelt es sich im Allgemeinen um einen Spin-Vorgang ist eine kontinuierliche Wiederholung.
2. Pessimistische Sperre
Gehen Sie immer vom schlimmsten Fall aus, wenn Sie Daten abrufen, und denken Sie, dass andere Threads diese ändern werden. Daher werden Sie Sperren hinzufügen (Lesesperren, Zeilensperren usw.). Andere Threads möchten auf Daten zugreifen, die blockiert und angehalten werden müssen. Sie können sich auf die Datenbankimplementierung verlassen, z. B. Zeilensperren, Lesesperren und Schreibsperren usw., die alle vor dem Betrieb gesperrt werden. In Java ist die Idee der synchronisierten Sperre ebenfalls pessimistisch.
3. Anwendbare Szenarien
Pessimistische Sperre: Sie eignet sich besser für Szenarien, in denen Schreibvorgänge häufiger vorkommen. Bei jedem Lesevorgang wird eine Sperre durchgeführt, was die Anzahl der Lesevorgänge erheblich erhöht Sperren Sie den Overhead und verringern Sie den Durchsatz des Systems.
Optimistische Sperre: Sie eignet sich besser für Szenarien mit häufigen Lesevorgängen. Wenn eine große Anzahl von Schreibvorgängen auftritt, erhöht sich die Möglichkeit von Datenkonflikten. Um die Konsistenz der Daten sicherzustellen, muss die Anwendungsschicht kontinuierlich aktualisiert werden -Erhalten Sie die Daten. Dies erhöht die Anzahl der Abfragevorgänge und verringert den Durchsatz des Systems.
Zusammenfassung: Beide haben ihre eigenen Vor- und Nachteile. Für häufige Lesevorgänge werden optimistische Sperren verwendet, für häufige Schreibvorgänge werden pessimistische Sperren verwendet.
Verwandte Empfehlungen:
Java-Einführungs-TutorialDas obige ist der detaillierte Inhalt vonJava-Interview – optimistisches Sperren und pessimistisches Sperren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Leitfaden zur perfekten Zahl in Java. Hier besprechen wir die Definition, Wie prüft man die perfekte Zahl in Java?, Beispiele mit Code-Implementierung.

Leitfaden für Weka in Java. Hier besprechen wir die Einführung, die Verwendung von Weka Java, die Art der Plattform und die Vorteile anhand von Beispielen.

Leitfaden zur Smith-Zahl in Java. Hier besprechen wir die Definition: Wie überprüft man die Smith-Nummer in Java? Beispiel mit Code-Implementierung.

In diesem Artikel haben wir die am häufigsten gestellten Fragen zu Java Spring-Interviews mit ihren detaillierten Antworten zusammengestellt. Damit Sie das Interview knacken können.

Java 8 führt die Stream -API ein und bietet eine leistungsstarke und ausdrucksstarke Möglichkeit, Datensammlungen zu verarbeiten. Eine häufige Frage bei der Verwendung von Stream lautet jedoch: Wie kann man von einem Foreach -Betrieb brechen oder zurückkehren? Herkömmliche Schleifen ermöglichen eine frühzeitige Unterbrechung oder Rückkehr, aber die Stream's foreach -Methode unterstützt diese Methode nicht direkt. In diesem Artikel werden die Gründe erläutert und alternative Methoden zur Implementierung vorzeitiger Beendigung in Strahlverarbeitungssystemen erforscht. Weitere Lektüre: Java Stream API -Verbesserungen Stream foreach verstehen Die Foreach -Methode ist ein Terminalbetrieb, der einen Vorgang für jedes Element im Stream ausführt. Seine Designabsicht ist

Anleitung zum TimeStamp to Date in Java. Hier diskutieren wir auch die Einführung und wie man Zeitstempel in Java in ein Datum konvertiert, zusammen mit Beispielen.

Kapseln sind dreidimensionale geometrische Figuren, die aus einem Zylinder und einer Hemisphäre an beiden Enden bestehen. Das Volumen der Kapsel kann berechnet werden, indem das Volumen des Zylinders und das Volumen der Hemisphäre an beiden Enden hinzugefügt werden. In diesem Tutorial wird erörtert, wie das Volumen einer bestimmten Kapsel in Java mit verschiedenen Methoden berechnet wird. Kapselvolumenformel Die Formel für das Kapselvolumen lautet wie folgt: Kapselvolumen = zylindrisches Volumenvolumen Zwei Hemisphäre Volumen In, R: Der Radius der Hemisphäre. H: Die Höhe des Zylinders (ohne die Hemisphäre). Beispiel 1 eingeben Radius = 5 Einheiten Höhe = 10 Einheiten Ausgabe Volumen = 1570,8 Kubikeinheiten erklären Berechnen Sie das Volumen mithilfe der Formel: Volumen = π × R2 × H (4

Java ist eine beliebte Programmiersprache, die sowohl von Anfängern als auch von erfahrenen Entwicklern erlernt werden kann. Dieses Tutorial beginnt mit grundlegenden Konzepten und geht dann weiter zu fortgeschrittenen Themen. Nach der Installation des Java Development Kit können Sie das Programmieren üben, indem Sie ein einfaches „Hello, World!“-Programm erstellen. Nachdem Sie den Code verstanden haben, verwenden Sie die Eingabeaufforderung, um das Programm zu kompilieren und auszuführen. Auf der Konsole wird „Hello, World!“ ausgegeben. Mit dem Erlernen von Java beginnt Ihre Programmierreise, und wenn Sie Ihre Kenntnisse vertiefen, können Sie komplexere Anwendungen erstellen.
