Heim >Java >javaLernprogramm >Zusammenfassung und Analyse des Multithreading-Wissens in Java
Der Inhalt dieses Artikels ist eine Zusammenfassung und Analyse des Multithreading-Wissens in Java. Ich hoffe, dass er für Freunde hilfreich ist.
Prozess: Ein laufendes Programm ist eine unabhängige Einheit zur Ressourcenzuweisung und zum Aufruf durch das System.
Ein Prozess ist ein dynamischer Ausführungsprozess eines Programms auf einem Datensatz.
Ein Prozess besteht im Allgemeinen aus drei Teilen: Programm, Datensatz und Prozesssteuerungsblock.
Jeder Prozess verfügt über seinen eigenen Speicherplatz und seine eigenen Systemressourcen.
Das von uns geschriebene Programm wird verwendet, um zu beschreiben, welche Funktionen der Prozess ausführen möchte und wie er ausgeführt werden soll.
Der Datensatz ist was Das Programm verwendet Ressourcen, die während der Ausführung verwendet werden sollen Verwenden Sie es, um den Prozess zu steuern und zu verwalten. Es handelt sich um einen systembewussten Prozess. Die eindeutige Kennung ist vorhanden.
Beispiel für den Prozess:
(1) Stellen Sie sich vor, ein Informatiker mit guten Kochkenntnissen backt einen Geburtstagskuchen für seine Tochter
(2) Er hat ein Rezept zum Backen einer Geburtstagstorte und hat die nötigen Zutaten in der Küche: Mehl, Eier, Zucker usw. (5) Die verschiedenen Rohstoffe für die Herstellung des Kuchens sind die Eingabedaten.
(6) Der Prozess ist die Summe einer Reihe von Aktionen, bei denen der Koch das Rezept liest, verschiedene Zutaten beschafft und den Kuchen backt.
(7) Nehmen wir nun an, dass der Sohn des Informatikers weinend herauskommt und sagt, dass sein Kopf von einer Biene gestochen wurde;
(8) Der Informatiker zeichnet auf, was er gemäß dem Rezept getan hat, und zwar zum Speichern den aktuellen Stand des Prozesses;
(9) Nehmen Sie dann ein Erste-Hilfe-Handbuch heraus und befolgen Sie die Anweisungen zur Behandlung des Stichs.
(10) Zu diesem Zeitpunkt werden wir sehen, wie der Prozessor von einem Prozess zum anderen wechselt -Prioritätsprozesse;
(11) Jeder Prozess hat sein eigenes Programm (Rezepte und Erste-Hilfe-Handbücher); (12) Nachdem der Bienenstich behandelt wurde, kommt der Informatiker zurück, um Kuchen zu backen; 13) Machen Sie dort weiter, wo er aufgehört hat.
Thread-Übersicht
Die Entstehung von Threads dient dazu, den Verbrauch von Kontextwechseln zu reduzieren und die Parallelität des Systems zu verbessern.
Threads durchbrechen den Mangel, dass ein Prozess nur eine Sache tun kann, und ermöglichen so eine prozessinterne Parallelität.
(1) Angenommen, ein Textprogramm muss Tastatureingaben empfangen, den Inhalt auf dem Bildschirm anzeigen und die Informationen auf der Festplatte speichern.
(2) Wenn es nur einen Prozess gibt, entsteht zwangsläufig die Peinlichkeit, nur eine Sache gleichzeitig tun zu können, was bedeutet, dass beim Speichern keine Tastatureingabe möglich ist(3) Wenn mehrere Prozesse vorhanden sind, ist jeder Prozess für eine Aufgabe verantwortlich. (4) Prozess A ist für die Tastatureingabe verantwortlich, Prozess B ist für die Anzeige von Inhalten auf dem Bildschirm verantwortlich und Prozess C ist für das Speichern von Inhalten auf der Festplatte verantwortlich Festplatte;
(5) Die Zusammenarbeit zwischen A, B und C beinhaltet hier Prozesskommunikationsprobleme, und alle benötigen denselben Inhalt: Textinhalte;(7) Wenn es einen Mechanismus gibt, der es A, B und C ermöglicht, Ressourcen zu teilen
(8) Auf diese Weise müssen weniger Inhalte für den Kontextwechsel gespeichert und wiederhergestellt werden(9 ) Gleichzeitig kann es den durch die Kommunikation verursachten Leistungsverlust reduzieren.
(10) Dieser Mechanismus ist Thread.
Threads werden auch Lightweight-Prozesse genannt.
Es handelt sich um eine grundlegende CPU-Ausführungseinheit und die kleinste Einheit im Programmausführungsprozess.
Bestehend aus Thread-ID, Programmzähler, Registersatz und Stapel
Die Einführung von Threads reduziert den Overhead der gleichzeitigen Ausführung von Programmen und verbessert die Parallelitätsleistung des Betriebssystems.
Threads haben keine eigenen Systemressourcen.
Die Beziehung zwischen Prozess und Thread
Ein Prozess ist eine laufende Aktivität eines Programms im Computer für eine bestimmte Datensammlung.
Ein Thread ist ein Entität des Prozesses und ist die Grundeinheit der CPU-Planung und -Verteilung
Ein Thread ist eine Grundeinheit, die kleiner als ein Prozess ist und unabhängig ausgeführt werden kann
Die Beziehung zwischen Prozessen und Threads:
(1) Ein Thread kann nur zu einem Prozess gehören, und ein Prozess kann mehrere Threads haben, aber es gibt mindestens einen Thread
(2) Ressourcen werden Prozessen zugewiesen, derselbe Prozess Alle Threads teilen sich alle Ressourcen des ProzessesFunktionsprinzip des Java-Programms
Der Java-Befehl startet die Java Virtual Machine, also die JVM, was dem Starten einer Anwendung entspricht, also Starten eines Prozesses;
Dann ruft der Hauptthread die Hauptmethode einer bestimmten Klasse auf.
Die Hauptmethode wird also im Hauptthread ausgeführt, und alle Programme davor sind Single-Threaded.
JVM-Startup ist Multi-Threaded:
(1) Da der Garbage-Collection-Thread auch beim Start der JVM gestartet werden muss, kommt es sonst leicht zu einem Speicherüberlauf
(2) Der aktuelle Garbage-Collection-Thread plus der vorherige Hauptthread Es werden mindestens zwei Threads gestartet, sodass der Start von JVM mehrere Threads umfasst.
Machen Sie sich bereit: der Status des Threads
Methode der inneren Stärke: Methoden (Mechanismen), die jedes Objekt hat
Taizu Changquan: Grundlegende Fadenklasse
Neun-Yin-Handbuch: Fortgeschrittene Multi- Thread-Kontrollklasse
Neu: Neuer Status, wenn das Thread-Objekt erstellt wird, das heißt, Geben Sie den neuen Status ein, z. B.: Thread t = new MyThread()
Runnable: Bereitstatus, wenn die start()-Methode (t.start()) des Thread-Objekts ist aufgerufen, Der Thread wechselt in den Bereitschaftszustand. Der Thread im Bereitschaftszustand bedeutet nur, dass der Thread jederzeit bereit ist und auf die Ausführung der CPU-Planung wartet. Dies bedeutet nicht, dass der Thread sofort nach der Ausführung von t.start()
(2) Wenn ein Thread zur Ausführung in den laufenden Zustand wechseln möchte, muss er sich zunächst im Bereitschaftszustand befinden
(3) Je nach Ursache der Blockierung kann der Blockierungszustand in drei Typen unterteilt werden :
[1] Warten auf Blockierung: Der Thread im laufenden Zustand führt die Methode wait() aus, wodurch dieser Thread in den Wartezustand wechselt.
[2] Synchrone Blockierung: Wenn der Thread nicht erfasst werden kann Die synchronisierte Synchronisationssperre (da die Sperre von anderen Threads belegt ist) wechselt in den synchronisierten Blockierungsstatus
[3] Andere Blockierung: Durch Aufrufen von sleep() oder bei join() des Threads oder einer E/A-Anfrage ausgegeben, wechselt der Thread in den Blockierungsstatus. Wenn der Zustand „sleep()“ abläuft, wartet „join()“ darauf, dass der Thread beendet wird oder abläuft oder die E/A-Verarbeitung abgeschlossen ist, und der Thread wechselt wieder in den Bereitschaftszustand
(2) Jedes Java-Objekt verfügt über einen Monitor, um den Wiedereintritt von gleichzeitigem Code zu überwachen.
(3) Der Monitor funktioniert nicht, wenn er in Nicht-Multithreads codiert. Im Gegenteil, wenn er innerhalb des synchronisierten Bereichs liegt, funktioniert der Monitor
(2) Wenn ThreadLocal zum Verwalten von Variablen verwendet wird, wird ThreadLocal von jedem Thread bereitgestellt, der die Variable verwendet eine unabhängige Kopie der Variablen, sodass jeder Thread seine eigene Kopie unabhängig ändern kann, ohne dass dies Auswirkungen auf die entsprechenden Kopien anderer Threads hat.
(3) Wird häufig zur Steuerung der Benutzeranmeldung verwendet, z. B. zum Aufzeichnen von Sitzungsinformationen.
Das obige ist der detaillierte Inhalt vonZusammenfassung und Analyse des Multithreading-Wissens in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!