Threadpool
Ein Threadpool ist ein Softwareentwurfsmuster, das zur Verwaltung und Wiederverwendung von Threads in der Parallelprogrammierung verwendet wird. Es dient dazu, die Effizienz und die Reaktionszeit von Anwendungen zu verbessern, indem die Kosten für das Erstellen und Zerstören von Threads minimiert werden. In einem Threadpool werden eine konkrete Anzahl von Threads vorgehalten, die bei Bedarf Aufgaben ausführen können. Dies ermöglicht eine bessere Kontrolle über die Anzahl der gleichzeitig ausgeführten Threads und die Ressourcenauslastung des Systems.[1]
Funktionsweise
[Bearbeiten | Quelltext bearbeiten ]Ein Threadpool besteht typischerweise aus den folgenden Komponenten:
- Threadpool-Manager: Verwaltet den Pool von Threads und steuert die Zuweisung von Aufgaben an die Threads.
- Aufgabenwarteschlange: Enthält die Aufgaben, die von den Threads ausgeführt werden sollen.
- Threads: Die Arbeitseinheiten, die die Aufgaben aus der Warteschlange abarbeiten.
Ablauf
[Bearbeiten | Quelltext bearbeiten ]- Aufgaben einreichen: Eine Anwendung reicht eine Aufgabe in die Aufgabenwarteschlange des Threadpools ein.
- Aufgabenverteilung: Der Threadpool-Manager weist die Aufgabe einem verfügbaren Thread zu. Wenn keine Threads verfügbar sind, bleibt die Aufgabe in der Warteschlange, bis ein Thread frei wird.
- Aufgabenausführung: Der Thread führt die ihm zugewiesene Aufgabe aus. Nach Abschluss der Aufgabe steht der Thread wieder zur Verfügung, um eine neue Aufgabe zu übernehmen.
Vorteile
[Bearbeiten | Quelltext bearbeiten ]Durch die Wiederverwendung von Threads werden die Kosten für das Erstellen und Zerstören von Threads gesenkt. Zudem ermöglicht der Threadpool eine bessere Steuerung der Parallelität, indem er die maximale Anzahl der gleichzeitig aktiven Threads begrenzt.[2]
Einzelnachweise
[Bearbeiten | Quelltext bearbeiten ]- ↑ Thread Pools (The JavaTM Tutorials > Essential Java Classes > Concurrency). Abgerufen am 14. Juni 2024.
- ↑ Allen I. Holub: Taming Java threads: comprehensive coverage or multithreaded programming including careful treatment of subtleties and "gotchas" not found anywhere else; learn to anticipate and solve hidden problems within Java's threading models; necessary of those writing sophisticated applications in both the Java AWT and Swing (= Books for professionals by professionals). Apress, Berkeley, Calif 2000, ISBN 978-1-893115-10-1.
Abstrakte Fabrik | Erbauer | Fabrikmethode | Prototyp | Singleton | Multiton | Objektpool
Adapter | Brücke | Decorator | Fassade | Fliegengewicht | Kompositum | Stellvertreter
Beobachter | Besucher | Interpreter | Iterator | Kommando | Memento | Schablonenmethode | Strategie | Vermittler | Zustand | Zuständigkeitskette | Interceptor | Nullobjekt | Protokollstapel
relationale Abbildung
Datentransferobjekt | Table Data Gateway | Row Data Gateway | Active Record | Unit of Work | Identity Map | Lazy Loading | Identity Field | Dependent Mapping | Embedded Value | Serialized LOB | Inheritance Mapper | Metadata Mapping | Query Object | Command-Query-Responsibility-Segregation
übermittlungsmuster
File Transfer | Shared Database | Remote Procedure Invocation | Messaging
Message | Command Message | Document Message | Event Message | Request-Reply | Return Address | Correlation Identifier | Message Sequence | Message Expiration | Format Indicator
Message Endpoint | Messaging Gateway | Messaging Mapper | Transactional Client | Polling Consumer | Event-driven Consumer | Competing Consumers | Message Dispatcher | Selective Consumer | Durable Subscriber | Idempotent Receiver | Service Activator
Message Channel | Point-to-Point Channel | Publisher-Subscriber Channel | Datatype Channel | Invalid Message Channel | Dead Letter Channel | Guaranteed Delivery | Channel Adapter | Messaging Bridge | Message Bus
Pipes-and-Filters | Message Router | Content-based Router | Message Filter | Dynamic Router | Recipient List | Splitter | Aggregator | Resequencer | Composed Message Processor | Scatter-Gather | Routing Slip | Process Manager | Message Broker
Message Translator | Envelope Wrapper | Content Enricher | Content Filter | Claim Check | Normalizer | Canonical Data Model
Control Bus | Detour | Wire Tap | Message History | Message Store | Smart Proxy | Test Message | Channel Purger
Application Controller | Business Delegate | Data Access Object | Dependency Injection | Extension Interface | Fluent Interface | Inversion of Control (IoC) | Lock | Model View Controller (MVC) | Model View Presenter (MVP) | Model View Update (MVU) | Model View ViewModel (MVVM) | Page Controller | Registry | Remote Facade | Repository | Service Locator | Session State | Table Module | Template View | Threadpool | Transaction Script | Transform View | Two-Step View | Value Object