Heim > häufiges Problem > Welche Beziehung besteht zwischen Threads und Prozessen?

Welche Beziehung besteht zwischen Threads und Prozessen?

青灯夜游
Freigeben: 2023-01-31 14:18:14
Original
12591 Leute haben es durchsucht

Beziehung: 1. Ein Prozess kann mehrere Threads haben, aber es gibt mindestens einen Thread und ein Thread kann nur im Adressraum eines Prozesses aktiv sein. 2. Ressourcen werden Prozessen zugewiesen, und alle Threads desselben Prozesses teilen sich alle Ressourcen des Prozesses. 3. Die CPU wird Threads zugewiesen, dh die Threads werden tatsächlich auf dem Prozessor ausgeführt. 4. Threads müssen während der Ausführung zusammenarbeiten und synchronisieren. Threads in verschiedenen Prozessen müssen Nachrichtenkommunikation verwenden, um eine Synchronisierung zu erreichen.

Welche Beziehung besteht zwischen Threads und Prozessen?

Die Betriebsumgebung dieses Tutorials: Windows 7-System, Dell G3-Computer.

Prozess ist die Grundeinheit der Ressourcenzuweisung, Thread ist die Grundeinheit der CPU-Planung und -Verteilung

Thread ist Teil des Prozesses, ein Thread kann nur zu einem Prozess gehören, ein Prozess kann mehrere Threads haben, aber es gibt at Mindestens ein Thread

Jeder Prozess verfügt über einen unabhängigen Code- und Datenraum (Programmkontext). Threads können als leichtgewichtige Prozesse desselben Typs betrachtet werden Beim Ausführen von Stapel- und Programmzählern (PC) sind die Kosten für den Wechsel zwischen Threads gering

Im Betriebssystem können mehrere Prozesse (Programme) gleichzeitig ausgeführt werden, und mehrere Threads werden gleichzeitig im selben Prozess (Programm) ausgeführt. (durch CPU-Planung wird in jeder Zeitscheibe nur ein Thread ausgeführt)

Das System weist jedem Prozess während der Ausführung unterschiedlichen Speicherplatz zu. Mit Ausnahme der CPU weist das System dem Thread (den Ressourcen) keinen Speicher zu Die vom Thread verwendeten Ressourcen stammen aus den Ressourcen des Prozesses, zu dem er gehört. Thread-Gruppen können nur Ressourcen gemeinsam nutzen.

Es gibt keinen vorgefertigten Prozess, der als Single-Threaded betrachtet werden kann Prozess, der Ausführungsprozess besteht nicht aus einer Zeile, und mehrere Zeilen (Threads) sind üblich. Vollständig
Threads sind Teil des Prozesses, daher werden Threads als leichte Prozesse/leichtgewichtige Prozesse bezeichnet

Die Beziehung zwischen Prozessen und Threads

1. Ein Prozess kann mehrere Threads haben, aber es gibt mindestens einen Thread. Ein Thread kann nur im Adressraum eines Prozesses aktiv sein.

2. Ressourcen werden Prozessen zugewiesen und alle Threads desselben Prozesses teilen sich alle Ressourcen des Prozesses.

3. Die CPU ist Threads zugeordnet, das heißt, die Threads laufen tatsächlich auf dem Prozessor.

4. Threads müssen während der Ausführung zusammenarbeiten und synchronisieren. Threads in verschiedenen Prozessen müssen Nachrichtenkommunikation verwenden, um eine Synchronisierung zu erreichen.

Was kann zwischen Prozessen geteilt werden?

Die von Threads gemeinsam genutzte Umgebung umfasst: Prozesscodesegmente, öffentliche Daten des Prozesses (mithilfe dieser gemeinsam genutzten Daten können Threads problemlos miteinander kommunizieren), vom Prozess geöffnete Dateideskriptoren, Signalhandler, Prozesse Das aktuelle Verzeichnis und Prozessbenutzer-ID und Prozessgruppen-ID.

Während Prozesse viele Gemeinsamkeiten aufweisen, haben sie auch ihre eigene Persönlichkeit. Mit diesen Persönlichkeiten können Threads Parallelität erreichen. Zu diesen Persönlichkeiten gehören:

1. Thread-ID
Jeder Thread hat seine eigene Thread-ID, die in diesem Prozess eindeutig ist. Prozesse nutzen dies, um Threads zu identifizieren.

2. Registersatzwert
Da Threads gleichzeitig ausgeführt werden, hat jeder Thread seine eigenen unterschiedlichen Laufhinweise. Beim Wechsel von einem Thread zum anderen muss der Registersatz des ursprünglichen Threads gespeichert werden Es kann wiederhergestellt werden, wenn der Thread in Zukunft wieder darauf umgeschaltet wird.

3. Thread-Stack
Stack ist notwendig, um sicherzustellen, dass Threads unabhängig voneinander ausgeführt werden können.
     Thread-Funktionen können Funktionen aufrufen und die aufgerufenen Funktionen können Schicht für Schicht verschachtelt werden. Daher muss der Thread über einen eigenen Funktionsstapel verfügen, damit der Funktionsaufruf normal ausgeführt werden kann, ohne von anderen Threads beeinflusst zu werden.

4. Fehlerrückgabecode
Da viele Threads gleichzeitig im selben Prozess laufen, ist es möglich, dass ein Thread den errno-Wert nach einem Systemaufruf und bevor der Thread den Fehler verarbeitet hat, festlegt. Ein anderer Thread wird zu diesem Zeitpunkt vom Scheduler in Betrieb genommen, sodass der Fehlerwert möglicherweise geändert wird.

Daher sollten verschiedene Threads ihre eigenen Fehlerrückgabecodevariablen haben.

5. Signalmaskierungscode des Threads
Da jeder Thread an unterschiedlichen Signalen interessiert ist, sollte der Signalmaskierungscode des Threads vom Thread selbst verwaltet werden. Aber alle Threads nutzen denselben Signalhandler.

6. Priorität des Threads
Da Threads wie Prozesse geplant werden müssen, müssen Parameter für die Planung verfügbar sein. Dieser Parameter ist die Priorität des Threads.

Fünf Möglichkeiten der prozessübergreifenden Kommunikation

1 (Unbenannte) Pipe

Halbduplex, das heißt, Daten können nicht gleichzeitig in beide Richtungen übertragen werden. Einige Systeme unterstützen möglicherweise Vollduplex.

Nur zwischen übergeordneten und untergeordneten Prozessen. Die klassische Form besteht darin, dass die Pipe vom übergeordneten Prozess erstellt wird. Nachdem der Prozess den untergeordneten Prozess gegabelt hat, kann sie zwischen dem übergeordneten und dem untergeordneten Prozess verwendet werden.

2. Named Pipe (FIFO)

Auch irrelevante Prozesse können Daten austauschen.

3. Nachrichtenwarteschlange

Die Nachrichtenwarteschlange ist eine verknüpfte Liste von Nachrichten, bei der es sich um eine Reihe von im Kernel gespeicherten Nachrichtenlisten handelt. Benutzerprozesse können Nachrichten zur Nachrichtenwarteschlange hinzufügen und Nachrichten aus der Nachrichtenwarteschlange lesen.

Im Vergleich zur Pipeline-Kommunikation besteht der Vorteil der Nachrichtenwarteschlange darin, dass für jede Nachricht ein bestimmter Nachrichtentyp angegeben werden kann. Beim Empfang müssen Sie sich nicht an die Warteschlangenreihenfolge halten, sondern können bestimmte Nachrichtentypen basierend auf benutzerdefinierten Bedingungen empfangen.

Sie können sich eine Nachricht als einen Datensatz mit einem bestimmten Format und einer bestimmten Priorität vorstellen. Ein Prozess mit Schreibberechtigungen für die Nachrichtenwarteschlange kann nach bestimmten Regeln neue Nachrichten zur Nachrichtenwarteschlange hinzufügen, und ein Prozess mit Leseberechtigungen für die Nachrichtenwarteschlange kann Nachrichten aus der Nachrichtenwarteschlange lesen.

4. Semaphor

Der Semaphor ist ein Zähler, der hauptsächlich dann verwendet wird, wenn mehrere Prozesse auf gemeinsame Daten zugreifen müssen. In Anbetracht dieser Situation können zwei Prozesse nicht gleichzeitig auf dieselben Daten zugreifen, sodass dies mithilfe von Semaphoren erreicht werden kann.

Sein Hauptprozess ist wie folgt:

Überprüfen Sie das Semaphor, das die Ressource steuert.

Wenn der Semaphorwert größer als 0 ist, ist die Ressource verfügbar, und dekrementieren Sie ihn um 1, was anzeigt, dass sie derzeit verwendet wird.

Wenn die Der Semaphorwert ist 0. Der Prozess schläft, bis der Semaphorwert größer als 0 ist. Mit anderen Worten, er stellt tatsächlich ein Mittel zur Zugriffssynchronisierung zwischen verschiedenen Prozessen oder verschiedenen Threads eines Prozesses bereit.

5. Gemeinsamer Speicher

Mit dem gemeinsamen Speicher können zwei oder mehr Prozesse einen eigenen Adressraum abbilden. Die von einem Prozess geschriebenen Informationen werden gemeinsam genutzt Der Speicher kann von anderen Prozessen, die diesen gemeinsam genutzten Speicher verwenden, durch einfaches Lesen des Speichers ausgelesen werden, wodurch eine Kommunikation zwischen Prozessen realisiert wird.

Einer der Hauptvorteile der Verwendung von Shared Memory für die Kommunikation ist die hohe Effizienz, da der Prozess den Speicher direkt lesen und schreiben kann, ohne dass Daten kopiert werden müssen. Bei Kommunikationsmethoden wie Pipes und Nachrichtenwarteschlangen müssen diese im ausgeführt werden Kernel- und Benutzerbereich werden viermal kopiert, während der gemeinsame Speicher nur zweimal kopiert wird: einmal von der Eingabedatei in den gemeinsam genutzten Speicherbereich und das andere Mal vom gemeinsam genutzten Speicher in die Ausgabedatei.

Wenn Prozesse den Speicher gemeinsam nutzen, wird die Zuordnung nach dem Lesen und Schreiben einer kleinen Datenmenge im Allgemeinen nicht aufgehoben und der gemeinsam genutzte Speicherbereich bei einer neuen Kommunikation wiederhergestellt. Stattdessen bleibt der gemeinsam genutzte Bereich erhalten, bis die Kommunikation erfolgt Auf diese Weise wird der Dateninhalt immer im gemeinsamen Speicher gespeichert und nicht in die Datei zurückgeschrieben. Der Inhalt im gemeinsam genutzten Speicher wird häufig in die Datei zurückgeschrieben, wenn die Zuordnung aufgehoben wird. Daher ist die Kommunikationsmethode über den gemeinsam genutzten Speicher sehr effizient.

6. Socket:

Socket ist im Gegensatz zu anderen Kommunikationsmechanismen auch für die Prozesskommunikation zwischen verschiedenen Computern geeignet. 7. Signal (Sinal)

Das obige ist der detaillierte Inhalt vonWelche Beziehung besteht zwischen Threads und Prozessen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage