AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

TParallel.For - Liste durchlaufen

Ein Thema von a.def · begonnen am 26. Dez 2016 · letzter Beitrag vom 27. Dez 2016
Antwort Antwort
a.def
(Gast)

n/a Beiträge
 
#1

TParallel.For - Liste durchlaufen

  Alt 26. Dez 2016, 16:26
Ich möchte jetzt auch endlich mal in den Geschmack von TParallel.For kommen und baue das gerade in ein(e) Demo ein.

Gegeben ist eine TObjectList mit einigen Einträgen. Hinter jedem Eintrag liegt ein Record mit Strings (existierende Dateinamen, erstellt mit FileFiller) und mehr.

Ich gehe diese Liste nun mit einer normalen For-Schleife durch und prüfe bei jedem Eintrag, ob die Datei die im Record steckt in Benutzung ist/exklusiv geöffnet ist.
Wenn ja, wird der Eintrag aus der TObjectList geschmissen. Mit der normalen For-Schleife selbstverständlich kein Problem und schon X-Mal gemacht.

Die TParallel.For jedoch scheint in mehreren Threads (die sie ja scheinbar erstellt), auf dieselben Dateien zuzugreifen und dann kommt natürlich
Zitat:
Im Projekt DemoTParallel.exe ist eine Exception der Klasse EFOpenError mit der Meldung 'Datei E:\Delphi\_FileFillerDumps\XXXXXX.txt kann nicht geöffnet werden.
Der Prozess kann nicht auf die Datei zugreifen, da sie von einem anderen Prozess verwendet wird' aufgetreten.
(XXXX steht für irgendeine Datei, es ist immer eine andere)

Mache ich etwas falsch, habe ich etwas vergessen?
Ich dachte TParallel.For sorgt selbständig dafür, dass die Einträge 0 bis Count-1 auf Threads verteilt werden (0, FaFileList.Count - 1).

Geändert von a.def (26. Dez 2016 um 16:30 Uhr)
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#2

AW: TParallel.For - Liste durchlaufen

  Alt 26. Dez 2016, 16:32
Wenn ja, wird der Eintrag aus der TObjectList geschmissen.
Da wird wahrscheinlich das Problem sein. Du darfst die Liste natürlich nicht modifizieren, während du sie mit TParallel durchläufst.
  Mit Zitat antworten Zitat
a.def
(Gast)

n/a Beiträge
 
#3

AW: TParallel.For - Liste durchlaufen

  Alt 26. Dez 2016, 16:33
Ich hätte erwähnen sollen, dass das nicht in der TParallel-Schleife passiert sondern später.
Es wird in der TParallel-Schleife nur ein Flag gesetzt, was später ausgewertet wird.
Bis zum Setzen des Flags kommt es aber nicht einmal, da schon vorher die Exception kommt.

Der Debugger sagt, der Fehler liegt in der Zeile in welcher ich prüfe, ob eine Datei in Benutzung ist.
Deswegen denke ich ja, dass TParallel mehrmals auf dieselben Einträge zugreift, was nicht passieren sollte.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.009 Beiträge
 
Delphi 12 Athens
 
#4

AW: TParallel.For - Liste durchlaufen

  Alt 26. Dez 2016, 16:50
Ohne Sourcen ist das nur äusserst schwer zu erraten
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
a.def
(Gast)

n/a Beiträge
 
#5

AW: TParallel.For - Liste durchlaufen

  Alt 26. Dez 2016, 16:58
Ich habe meinen ehrlich gesagt dummen Fehler gerade gefunden.
Ich hatte in meiner Prozedur eine Variable X deklariert, welche ich dann in der TParallel.For-Schleife verwendet habe
  Mit Zitat antworten Zitat
a.def
(Gast)

n/a Beiträge
 
#6

AW: TParallel.For - Liste durchlaufen

  Alt 27. Dez 2016, 13:36
Ich habe eine etwas größere Funktion nun auf von For auf TParallel.For umgestellt.

Die Dauer die diese Funktion mit der normalen For-Schleife und sequenzieller Abarbeitung der Liste benötige, belief sich auf etwa 16,8 Minuten im Durchschnitt.
Mit der TParallel.For-Schleife liegt der Durchschnitt bei 6,71 Minuten pro Aufruf.

Hat sich also gelohnt die Arbeit.
Mir sind zwar anfangs die Fehlermeldungen und Memory-Leaks um die Ohren geflogen, aber nach abändern einiger Gefahrenstellen (TInterlock.Add statt Inc usw.) und TThread.Queue (um pro Iteration in eine StringList zu schreiben) sind auch diese nun behoben.

Und da hätte ich auch noch eine hoffentlich abschließende Frage:
muss TThread.Queue zwingend aus einem Thread aufgerufen werden oder kann ich das auch in einer Funktion aufrufen, welche durch meinen Thread aufgerufen wird?

Geändert von a.def (27. Dez 2016 um 13:43 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.346 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: TParallel.For - Liste durchlaufen

  Alt 27. Dez 2016, 15:04
Du kannst das an beliebiger Stelle im Kontext des Threads machen. Auch in einer aufgerufenen Funktion in einer anderen Unit.
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
Antwort Antwort


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 14:41 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz