AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

Ein Thema von karlkoch · begonnen am 26. Okt 2020 · letzter Beitrag vom 28. Okt 2020
Antwort Antwort
karlkoch

Registriert seit: 26. Feb 2006
Ort: Leipzig
30 Beiträge
 
Delphi 10.4 Sydney
 
#1

AW: Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

  Alt 26. Okt 2020, 15:21
Ok, bisher bin ich mit eigenen Entwicklungen gut gefahren, war jedoch der Hoffnung, meine Implementierungen schrittweise durch "native" Unterstützungen zu ersetzen. Schade, dann ist die PPL immer noch nicht für meine Zwecke geeignet.

Viele Grüße,

karlkoch
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.154 Beiträge
 
Delphi 10.3 Rio
 
#2

AW: Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

  Alt 27. Okt 2020, 12:52
Ok, bisher bin ich mit eigenen Entwicklungen gut gefahren, war jedoch der Hoffnung, meine Implementierungen schrittweise durch "native" Unterstützungen zu ersetzen. Schade, dann ist die PPL immer noch nicht für meine Zwecke geeignet.
Wenn man als Werkzeug nur einen Hammer hat, sehen alle Ziele wie ein Nagel aus...

Sicherlich kann man viele Hintergrundverarbeitung mit der PPL lösen, aber wie immer bei Lösungen nach dem Motto "One fits all", gibt es in der Regel eine
spezielle Lösung für ein Problem, dass der Anforderung besser gerecht wird.

Die PPL ist sehr gut für "shot and forget" geeignet. Spätestens, wenn es sich nicht um "Schön-Wetter-Code" handelt und ggf. Fehlermeldung/Exceptions zu erwarten sind,
muss man sich auch mit der PPL schon Gedanken machen.

Also bei Hintergrundverarbeitungen z.b. in Apps für iOS & Android, bei denen möglichst alles was nicht auf die UI zugreift, im Hintergrund ausgeführt werden sollte, ist die
PPL sehr hilfreich bis zu - ohne geht es kaum.

Daher - immer das richtige Werkzeug für das zu lösende Problem verwenden!

Mavarik
  Mit Zitat antworten Zitat
karlkoch

Registriert seit: 26. Feb 2006
Ort: Leipzig
30 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

  Alt 27. Okt 2020, 22:28
Hallo,

an sich bin ich mit der PPL zufrieden, es fehlen nur Kleinigkeiten, um mein Vorhaben mit der Library umzusetzen.

Eigentlich ist das Problem gar nicht mehr die fehlende Priorisierung, sondern die Möglichkeit, die maximale Anzahl gleichzeitig abzuarbeitender Tasks zu beschränken. Meine Idee ist, durch einen eigenen "Scheduler" die vielen Tasks zunächst in einer eigener Queue zu sammeln und immer nur dann an die PPL zu übergeben (ITask.Start), wenn aktuell nicht mehr als X Tasks ausgeführt werden. Gerade bei Festplatten- oder Datenbankzugriffen darf es nicht zu viele gleichzeitige Tasks geben, wobei TThreadPool.SetMaximumWorkerThreads keine Abhilfe schafft, weil dieser Wert an die CPU-Kerne gebunden ist.

Leider scheitert mein Vorhaben aktuell daran, dass ich es nicht schaffe, auf saubere Art und Weise extern über die Fertigstellung eines Tasks informiert zu werden, damit ich die nächsten Tasks rausschicken kann (egal ob ein Task ausgeführt, abgebrochen oder durch einen Fehler beendet wurde). Interessant sieht für mich TTask.ProcessCompleteEvents aus, weil das immer am Ende eines Tasks aufgerufen wird, allerdings verhindert TTask eine Ableitung, sodass ich diese Methode überschreiben könnte.

Oder hat jemand einen anderen Ansatz für mich?

Viele Grüße,

karlkoch
  Mit Zitat antworten Zitat
Benutzerbild von Sinspin
Sinspin

Registriert seit: 15. Sep 2008
Ort: Dubai
717 Beiträge
 
Delphi 10.3 Rio
 
#4

AW: Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

  Alt 28. Okt 2020, 08:59
Hallo.
Warum willst du das Event ableiten? Schreib doch einfach einen Handler dafür. In dem machst du nichts anderes als einen Zähler zu erhöhen. Beim Start eines neuen Tasks erhöst du einen anderen Zähler.
Du startest dann einfach weitere Tasks bis dir der Abstand zwischen den beiden Zählern zu groß wird. Bzw. wieder neue wenn der Abstand wieder passt.
Stefan
Nur die Besten sterben jung
A constant is a constant until it change.
  Mit Zitat antworten Zitat
karlkoch

Registriert seit: 26. Feb 2006
Ort: Leipzig
30 Beiträge
 
Delphi 10.4 Sydney
 
#5

AW: Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

  Alt 28. Okt 2020, 09:38
Warum willst du das Event ableiten? Schreib doch einfach einen Handler dafür.
Die PPL ruft diesen Handler, soweit ich das überblicke und testen konnte, jedoch nicht immer auf, z.B. nicht, wenn ein Task noch vor dem Start abgebrochen wird (oder auf dem Weg zwischen Start und Verarbeitung im Workerthread). Sobald ein Scheduler einen Tasks an die PPL schickt (ITask.Start), müsste garantiert werden, dass in jedem Fall ein Handler für diesen Task aufgerufen wird, was meiner Meinung nach im Moment nicht der Fall ist.

Viele Grüße,

karlkoch
  Mit Zitat antworten Zitat
karlkoch

Registriert seit: 26. Feb 2006
Ort: Leipzig
30 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

  Alt 28. Okt 2020, 11:07
Hallo,

meine aktuelle Lösung sieht folgendermaßen aus:
Delphi-Quellcode:
TMyTask = class(TAbstractTask);

InternalTask := TMyTask.IInternalTask(Task);
InternalTask.AddCompleteEvent(
  procedure (Task: ITask)
  begin
    // Task ist fertig
  end
);
Das funktioniert, egal ob ein Task abgebrochen oder verarbeitet wurde, aber schöner fände ich es, wenn die PPL so ein Event öffentlich unterstützen würde, oder ich übersehe etwas.

Viele Grüße,

karlkoch
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.378 Beiträge
 
Delphi 12 Athens
 
#7

AW: Parallel Programming Library: Reihenfolge von Tasks (Priorisierung)

  Alt 28. Okt 2020, 11:38
Du kannst doch nachgucken?

* Schauen was AddCompleteEvent macht, also wo das Event gespeichert wird.
* wenn da dort mehreres registriert werden kann, schauen ob es auch eine globale Registrierung gibt
* dann gucken wo es aufgerufen wird und ob es dort auch einen Aufruf eines globalen Events gibt, bzw. ob diese Stelle überschreibbar ist

...
Am Ende ist TTask.ProcessCompleteEvents virtual und kann somit überschrieben/erweitert werden.


Und ich hoffe dein Task läuft nicht schon, denn wenn er gerade fertig wird, während du dein Event registriert, kann es passieren, dass dein Event nicht aufgerufen wird.
[EDIT] OK, falls ich nicht nochwas übersehn hab, dann sollte es doch nicht passieren.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (28. Okt 2020 um 11:41 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:55 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