![]() |
ThreadHelper - Prozeduren als Thread laufen lassen
Liste der Anhänge anzeigen (Anzahl: 5)
Vornweg: Hierfür sind die Generics notwendig.
Also, nix Weltbewegendes .. hiermit kann man halt einfach nur verschiedene Prozeduren in eigenen Threads laufen lassen. Diese Prozeduren können, unter Anderem Dank der Generics, auch mit eigenen Parameterdefinitionen versehen sein. Bis zu 3 Parameter sind möglich.
Delphi-Quellcode:
Leider gibt es keine Generics für Prozeduren :cry: , drum mußte ich alles in 'ner Klasse (TThreadHelper) kapseln.
Program ThreadHelperP;
Uses Windows, ThreadHelper; Procedure Proc(Helper: TThreadHelperClass; Const i: Integer); Begin Beep(1000, 500); Sleep(i); Beep(1000, 500); End; Procedure Proc2(Helper: TThreadHelperClass); Begin While Helper.Running do Begin Beep(5000, 200); Sleep(1000); End; End; Begin RunAsThread<Integer>(Proc, 3000); TThreadHelper.RunAsThread(Proc2); Sleep(10000); TThreadHelper.StopAllGlobalThreads; // warten bis alle Threads beendet wurden While TThreadHelper.ActiveGlobalThreads > 0 do Sleep(10); End. Geplant waren eigentlich nur die RunAsThread-Prozeduren, aber am Ende hatte es so wohl doch einige Vorteile. Innerhalb der Threads kann man, ebenso wie bei den Thread-Prozeduren, auch entsprechende Synchronize-Prozeduren aufrufen. Es ist also nicht nötig sich erst eine eigene TThread-Klasse abzuleiten oder sich mit der WinAPI auseinander zu setzen, sondern kann seine Prozedur einfach und direkt starten und das sogar mit Parametern, was doch sonst immer ein bissl schwieriger ist. [edit] In der 7zip liegt nun das Testprogramm, die Generics-Version und eine neue abgespreckte Version ohne Generics. |
AW: ThreadHelper - Prozeduren als Thread laufen lassen
|
AW: ThreadHelper - Prozeduren als Thread laufen lassen
durchaus auch einen Blick wert:
![]() Aktuell arbeitet Primož an der OTL 2.0, ein paar Informationen dazu hat er in seinem Blog schon veröffentlicht: ![]() |
AW: ThreadHelper - Prozeduren als Thread laufen lassen
Da find ich die Implementierung eines Futures von gabr besser (auch wenns nich 100%ig das gleiche ist). Außerdem ist es ein wenig unglücklich, dass die Procedure, die du ausführst schon so konstruiert sein muss, dass sie in nem ThreadHelper laufen kann.
|
AW: ThreadHelper - Prozeduren als Thread laufen lassen
jpg's kenn ich, aber wer sagt denn, daß man nicht auch mal rumspielen darf?
Wobei jbg's Code ja auf "brutale" Weise den Threadkontext tauscht und die Codeausführung vom aktuellen Thread in einen anderen verschiebt. Hier ist es einfach nur so, daß man einen TThread startet und seine Prozedur von da aus aufrufen läßt ... also ohne irgendwelche "Tricks" und somit wirt es auch keine Probleme geben, wenn sich mal irgendwo etwas ändert. (dir wird bestimmt nicht entfallen sein, daß jbg an seiner Lib schon eine ganze Weile arbeitet und es auch einige Problemchen gibt/gab.) Also im Prinzip nehme ich hier den "offiziellen" Standardweg über TThread, nur daß man statt selber ein TThread-Objekt zu erstellen und selber seine Funktion aufzurufen, dieses über einen vordefinierten TThread-Nachkommen aufrufen lassen kann. (Was aber nicht heißt, daß ich jbg's Code nicht cool finde :angel: ) OK, hab die Unit etwas abgespeckt und die Generics ausgebaut. Es wird nun zwar erstmal nur maximal ein Parameter unterstützt, aber das liese sich erweitern (hab halt einfach nur alles entfernt/umgebaut, was Generics benötigt). |
AW: ThreadHelper - Prozeduren als Thread laufen lassen
Kennen wir uns? Ein Bekannter verneint auch immer alles doppelt:
Delphi-Quellcode:
:lol:
(noWait: Boolean = False)
If not noWait Then Aber wie du bereits sagtest, find ich es gut Alternativprodukte zu haben. (Auch wenns für D2k9++ ist :() :thumb: |
AW: ThreadHelper - Prozeduren als Thread laufen lassen
Gut, 'ne kleine Version ohne Generics gibt's ja nun.
Ich weiß grade nicht seit wann die TObjectList das OwnsObject kennt, aber ab da sollte der Code nun laufen. Ansonsten müßte man noch was gegen das Speicherleck machen, welches ohne dieses entstehen würde. Zitat:
|
AW: ThreadHelper - Prozeduren als Thread laufen lassen
Danke. :wink:
OwnsObjects gibt es anscheinend schon ![]()
Code:
E: TThread.Start gibts auch noch nicht.
[DCC Fehler] ThreadHelperNonGen.pas(22): E1030 Ungültige Compileranweisung: 'POINTERMATH'
[DCC Fehler] ThreadHelperNonGen.pas(23): E1030 Ungültige Compileranweisung: 'STRINGCHECKS' Wurde ![]() ![]() ![]() |
AW: ThreadHelper - Prozeduren als Thread laufen lassen
OK, beim Class Destructor wußte ich nicht, seit wann es den gibt.
(hatte jetzt auch nicht dran gedacht diesen zu ersetzen ... war aber auch mein erstes Mal, wo ich diesen ausprobiert hatte) STRINGCHECKS gibt es erst seit Delphi 2009 und der Rest wurde auch rausgenommen/geändert. |
AW: ThreadHelper - Prozeduren als Thread laufen lassen
Zitat:
Es ist einfach 'ne Spielerei um etwas die Grenzen und Möglichkeiten von Generics auszuloten. Aber der praktische Nutzen ist im Prinzip nicht vorhanden. Warum sollte man diese unglückliche Prozedure mit maximal einem Parameter aufrufen, wenn man doch lediglich die TThread-Klasse ableiten braucht? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:57 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz