Heim Java javaLernprogramm Ausführliche Erläuterung der Java-Multithreading-Grundlagen

Ausführliche Erläuterung der Java-Multithreading-Grundlagen

Mar 28, 2017 pm 03:36 PM

1. Thread-Status

2. Thread-Synchronisierung

🎜>

4. Synchrone Sammlung

Thread-Status

Threads haben fünf Zustände: neu, bereit, läuft, blockiert oder beendet.

Neu: Erstellen Sie einen neuen Thread und der Thread wechselt in den neuen Status.

Bereit: Nach dem Aufruf der start()-Methode des Threads wechselt er in den Bereitschaftsstatus >

Ausführen: Wenn Sie CPU-Zeit erhalten, wechselt der Thread aus dem Bereitschaftszustand in den Ausführungszustand. Wenn die Zeitscheibe abläuft oder die yield()-Methode aufgerufen wird, wechselt der Ausführungszustandsthread möglicherweise in den Bereitschaftszustand

Blockieren: Rufen Sie die Methoden „join()“, „sleep()“ oder „wait()“ auf oder warten Sie auf das Ende der E/A.

Abgeschlossen: Wenn der Thread beendet ist Durch Ausführen der run()-Methode wird der Thread beendet.

Erstellen und Verwenden von Multi-Threads

Thread-Klassendiagramm

1. Erben Sie die Thread-Klasse, um einen neuen Thread zu erstellen

2. Implementieren Sie die Runnable

Schnittstelle und schreiben Sie sie neu run( )-Methode

PrintChar implementiert die Runnable-Schnittstelle und verwendet Thread, um einen Thread zu erstellen. Da die Thread-Klasse die Runnable-Schnittstelle implementiert, können Sie ein Objekt dieser Klasse erstellen und ihre Startmethode aufrufen, um den Thread

3 zu starten die Executor-Schnittstelle Zur Ausführung von Aufgaben im Thread-Pool steht die ExecutorService-Schnittstelle zur Verwaltung und Steuerung von Aufgaben zur Verfügung.

Thread-Synchronisierung

Wenn mehrere Threads gleichzeitig auf eine gemeinsam genutzte Ressource zugreifen, ist sie möglicherweise beschädigt. Wenn die Datenfelder beispielsweise in unterschiedlicher Reihenfolge geändert werden, kann der Endwert unsicher sein. Konkurrenzzustand: Wenn zwei oder mehr Aufgaben auf eine gemeinsame Ressource auf eine Weise zugreifen, die einen Konflikt verursacht, spricht man von einem Rennzustand. Um einen Rennzustand zu vermeiden, sollten mehrere Threads verhindert werden Geben Sie gleichzeitig einen bestimmten Teil des Programms ein. Dieser Teil des Programms wird als kritischer Abschnitt bezeichnet.

1. Sperrensynchronisierung verwenden

Java kann Sperren und Zustände explizit verwenden, um Threads zu synchronisieren. Eine Sperre ist eine Instanz der Lock-Schnittstelle, die Methoden zum Sperren und Freigeben von Sperren definiert.

RenntrantLock ist eine Implementierung von Lock, die zum Erstellen sich gegenseitig ausschließender Sperren verwendet wird. Sperren können für bestimmte Fairness-Richtlinien erstellt werden. Ein fairer Richtlinienwert von 1 ist wahr und stellt sicher, dass der Thread mit der längsten Wartezeit zuerst die Sperre erhält. Bei „false“ wird es an jeden wartenden Thread übergeben.


2. Thread-Zusammenarbeit

Objekte, die durch Aufruf der newCondition()-Methode des Lock-Objekts erstellt wurden, können verwendet werden Die Methoden „await()“, „signal()“ und „signalAll()“ ermöglichen eine gegenseitige Kommunikation zwischen Threads.

Wenn der Thread die Methode „await()“ aufruft, wechselt der Thread in den Wartezustand und wartet auf das Wecksignal.

3. Blockierungswarteschlange

kann den aktuellen Thread blockieren, bis sich Elemente in der Warteschlange befinden automatisch geweckt werden, was großen Komfort bietet.

Mehrere Blockierungswarteschlangen:

1: ArrayBlockingQueue verwendet ein Array, um eine Blockierungswarteschlange zu implementieren, und zum Erstellen muss eine Kapazitäts- oder optionale Fairnessstrategie angegeben werden.

2: LinkedBlockingQueue verwendet eine verknüpfte Liste, um a zu implementieren Blockierungswarteschlange. Kann unbegrenzt oder begrenzt erstellt werden.

3: PriorityBlockQueue-Prioritätswarteschlange, sortiert Elemente nach ihrer Priorität.

ArrayBlockingQueue-Datenfeld




Es ist ersichtlich, dass der Speicherplatz ein Array ist und eine Sperre verwendet wird .

Implementierung zweier wichtiger Methoden

Warten Sie, wenn die Warteschlange voll ist, und treten Sie der Warteschlange bei, wenn sie nicht voll ist. Verwenden Sie zu diesem Zeitpunkt die Sperrsynchronisierung

Warteschlange Warten Sie, wenn sie leer ist, und verlassen Sie die Warteschlange, wenn sie nicht leer ist.

Apps blockieren Warteschlangen

von As Wie aus dem Beispiel hervorgeht, stellt der Produzent Zahlen in die Warteschlange, der Verbraucher nimmt die Zahlen aus der Warteschlange und wartet, wenn die Warteschlange leer ist. Die Synchronisierung wurde in der Warteschlange ohne Verwendung von Sperren und Bedingungen implementiert.

3. Semaphor

Semaphor bezieht sich auf das Objekt, das auf gemeinsame Ressourcen zugreift. Bevor ein Thread auf eine Ressource zugreifen kann, muss er die Erlaubnis vom Semaphor einholen. Nach dem Zugriff auf die Ressource muss die Berechtigung an das Semaphor zurückgegeben werden.

Das Programm erstellt ein Semaphor mit einer Erlaubnis. Wenn einem Thread die Berechtigung erteilt wird, können andere Threads nicht auf die Ressource zugreifen, bis der vorherige Thread die Berechtigung freigibt.

Synchronisierte Sammlungen

Klassen im Java Collections-Framework sind nicht threadsicher; das heißt, wenn mehrere Threads gleichzeitig auf sie zugreifen Gleichzeitig mit der Aktualisierung können ihre Inhalte beschädigt sein. Sie können die Daten in der Sammlung schützen, indem Sie die Sammlung sperren oder synchronisieren

Verwandte Artikel:

Java-Implementierung von PUT, POST, Löschanforderung

Detaillierte Einführung in die Java-Programmierung, Zusammenfassung häufiger Probleme

Diagramm der Java-Remotekommunikation Einführung in die Technologie- und Prinzipanalyse

Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung der Java-Multithreading-Grundlagen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
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

Heiße KI -Werkzeuge

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Verbesserung der Lesbarkeit mit Kommentaren Verbesserung der Lesbarkeit mit Kommentaren Jul 18, 2025 am 04:46 AM

Der Schlüssel zum Schreiben guter Kommentare besteht darin, "warum" zu erklären, anstatt nur "was getan wurde", um die Lesbarkeit des Codes zu verbessern. 1. Kommentare sollten logische Gründe erklären, wie z. B. Überlegungen für die Wertauswahl oder -verarbeitung; 2. Verwenden Sie Absatzanmerkungen für eine komplexe Logik, um die Gesamtidee von Funktionen oder Algorithmen zusammenzufassen. Fegen regelmäßig Kommentare beibehalten, um die Konsistenz mit dem Code zu gewährleisten, irreführend und gegebenenfalls veraltete Inhalte zu löschen. V.

Tipps zum Schreiben von PHP -Kommentaren Tipps zum Schreiben von PHP -Kommentaren Jul 18, 2025 am 04:51 AM

Der Schlüssel zum Schreiben von PHP -Kommentaren liegt in der Klärung des Zwecks und der Spezifikationen. Kommentare sollten "Warum" und nicht "was getan" erklären, um Redundanz oder zu Einfachheit zu vermeiden. 1. Verwenden Sie ein einheitliches Format wie Docblock (/*/) für Klassen- und Methodenbeschreibungen, um die Lesbarkeit und die Kompatibilität der Werkzeuge zu verbessern. 2. Betonen Sie die Gründe für die Logik, z. B. warum JS -Sprünge manuell ausgeben müssen. 3. Fügen Sie eine Übersichtsbeschreibung vor komplexem Code hinzu, beschreiben Sie den Prozess in Schritten und helfen Sie, die Gesamtidee zu verstehen. V. Gute Anmerkungen können die Kommunikationskosten senken und die Effizienz der Code -Wartung verbessern.

Schreiben effektiver PHP -Kommentare Schreiben effektiver PHP -Kommentare Jul 18, 2025 am 04:44 AM

Kommentare können nicht nachlässig sein, da sie die Gründe für die Existenz des Codes und nicht die Funktionen erklären möchten, z. B. die Kompatibilität mit alten Schnittstellen oder Einschränkungen von Drittanbietern, sonst können Personen, die den Code lesen, nur auf Vermutungen angewiesen. Die Bereiche, die kommentiert werden müssen, umfassen komplexe bedingte Urteile, spezielle Fehlerbehandlungslogik und vorübergehende Bypass -Beschränkungen. Eine praktischere Möglichkeit, Kommentare zu schreiben, besteht darin, Einzelzeilen-Kommentare auszuwählen oder Kommentare basierend auf der Szene zu blockieren. Verwenden Sie Dokumentblock Kommentare, um Parameter zu erläutern und Werte zu Beginn von Funktionen, Klassen und Dateien zurückzugeben, und halten Sie die Kommentare aktualisiert. Für eine komplexe Logik können Sie dem vorherigen eine Zeile hinzufügen, um die Gesamtabsicht zusammenzufassen. Verwenden Sie gleichzeitig keine Kommentare zum Versiegelungscode, sondern verwenden Sie Versionsteuerungswerkzeuge.

Effektives PHP -Kommentar Effektives PHP -Kommentar Jul 18, 2025 am 04:33 AM

Der Schlüssel zum Schreiben von PHP -Kommentaren ist klar, nützlich und prägnant. 1. Kommentare sollten die Absicht hinter dem Code erläutern, anstatt nur den Code selbst zu beschreiben, z. B. den logischen Zweck komplexe bedingte Urteile zu erklären. 2. Fügen Sie Kommentare zu Schlüsselszenarien wie magische Werte, alte Codekompatibilität, API -Schnittstellen usw. hinzu, um die Lesbarkeit zu verbessern. 3. Vermeiden Sie doppelte Codeinhalte, halten Sie ihn präzise und spezifisch und verwenden Sie Standardformate wie PHPDOC. 4. Die Kommentare sollten synchron mit dem Code aktualisiert werden, um die Genauigkeit zu gewährleisten. Aus der Sicht anderer sollten gute Kommentare angesehen werden, die Kosten des Verständnisses senken und zu einem Codes verstehen, das Navigationsgerät versteht.

PHP -Entwicklungsumgebung Setup PHP -Entwicklungsumgebung Setup Jul 18, 2025 am 04:55 AM

Der erste Schritt besteht darin, das integrierte Umgebungspaket XAMPP oder MAMP auszuwählen, um einen lokalen Server zu erstellen. Der zweite Schritt besteht darin, die entsprechende PHP -Version entsprechend den Projektanforderungen auszuwählen und mehrere Versionen zu konfigurieren. Der dritte Schritt besteht darin, VSCODE oder PHPSTORM als Editor auszuwählen und mit Xdebug zu debuggen. Darüber hinaus müssen Sie Komponist, PHP_CODESNIFFER, PHPUNIT und andere Tools installieren, um die Entwicklung zu unterstützen.

PHP -Kommentarsyntax PHP -Kommentarsyntax Jul 18, 2025 am 04:56 AM

Es gibt drei allgemeine Möglichkeiten, PHP-Kommentare zu verwenden: Einzeilen-Kommentare sind geeignet, um die Codelogik kurz zu erklären, z. B. // oder # für die Erläuterung der aktuellen Zeile. Multi-Line-Kommentare /*...*/ eignen sich für eine detaillierte Beschreibung der Funktionen oder Klassen; Dokumentieren Sie Kommentare DocBlock beginnen mit /**, um Eingabeaufforderungsinformationen für die IDE bereitzustellen. Wenn Sie es verwenden, sollten Sie Unsinn vermeiden, weiterhin synchron aktualisieren und keine Kommentare verwenden, um Codes für lange Zeit zu blockieren.

PHP -Vergleich Operatoren PHP -Vergleich Operatoren Jul 18, 2025 am 04:57 AM

PHP -Vergleichsbetreiber müssen auf die Typ -Conversion -Probleme aufmerksam machen. 1. Verwendung == nur zu vergleichen, um Werte zu vergleichen, und die Typumwandlung wird durchgeführt, wie z. B. 1 == "1" ist wahr; 2. Verwendung ===, um den gleichen Wert zu benötigen wie der Typ, wie z. B. 1 === "1" ist falsch; 3. Größenvergleich kann für Werte und Zeichenfolgen wie "Apple" verwendet werden

PHP -Kommentare für Teams PHP -Kommentare für Teams Jul 18, 2025 am 04:28 AM

Der Schlüssel zum Schreiben von PHP -Kommentaren besteht darin, "Warum" und nicht "was zu tun" zu erklären, den Annotationsstil des Teams zu vereinen, doppelte Code -Kommentare zu vermeiden und Todo und Fixme -Tags vernünftigerweise zu verwenden. 1. Kommentare sollten sich darauf konzentrieren, die logischen Gründe für den Code zu erklären, wie z. B. Leistungsoptimierung, Algorithmusauswahl usw.; 2. Das Team muss die Annotationsspezifikationen vereinen, z. 3. Vermeiden Sie bedeutungslose Anmerkungen, die nur den Inhalt des Codes nacherdigen und die Geschäftsbedeutung ergänzen sollten. V.

See all articles