AGB  ·  Datenschutz  ·  Impressum  







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

Multithread DLLs - gemeinsamer Speicher

Ein Thema von Delphi-Narr · begonnen am 18. Apr 2014 · letzter Beitrag vom 18. Apr 2014
Antwort Antwort
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#1

Multithread DLLs - gemeinsamer Speicher

  Alt 18. Apr 2014, 11:12
Hallo,
ich entwickle ein Programm, welches mehrere (ebenfalls selbst geschriebene) DLLs lädt, welche jeweils wiederkehrende Aufgaben erfüllen sollen, bis das Hauptprogramm sie
beendet.
Jede dieser DLLs hat die gleiche Struktur, d.h. einen vorgegebenen Aufrufsablauf an Funktionen.
Deshalb sollen diese DLLs über das "Hauptprogramm" in je einer Klasse erzeugt werden, die die eigentliche Kommunikation mit der DLL übernimmt.
Da die DLLs teilweise für Aufgaben etwas länger brauchen, die aber für alle anderen DLLs nicht von Belang sind, sollen die wiederkehrenden Aufgaben in Threads
ausgelagert sein.
Eine DLL besteht hierbei aus
1) Einer Init Funktion
2) Einer Tick Funktion (Diese soll wiederholt aufgerufen werden!)
3) Funktionen, welche vom Hauptprogramm aus ausgelöst werden, um bestimmte Events (Relevanter Tastendruck etc.) zu signalisieren.
4) Einer exit Funktion

Nun kann es vorkommen, dass eine DLL einen Wert in der Tick Methode benötigt, der durch eine andere DLL berechnet wurde.
Bisher habe ich dies (Single Thread) über eine Callback Methode gelöst, welche relevante Werte an das Hauptprogramm schickt,
welches diese in einer Liste abspeichert und bei Bedarf wieder ausliest. So konnten alle DLLs darauf zugreifen.

Nun meine eigentliche Frage(n):
Geht das einfacher? Können die DLLs (ohne sich untereinander zu kennen) auf Variablen anderer DLLs zugreifen?
Und der Hauptpunkt: Wenn die DLLs in Threads laufen sollen, macht es Sinn, die gesamte Klasse, welche die DLL verwaltet, in einen Thread zu packen, oder nur die einzige rechenintensive Funktion Tick?
Und wie kann ich vom Hauptprogramm immer noch Events an die Threads schicken und wie können die DLLs aus ihrem Thread heraus Werte zurück an die DLL übergreifende Speicherverwaltung schicken?
Erledigt dies alles ein Memory Manager, sodass ich theoretisch jeder DLL beim starten einen Pointer auf die Liste mit Werten geben kann und der gleichzeitige Zugriff auf diesen Wert dann vom Memory Manager (FastMM4 in meinem Fall) verhindert bzw. koordiniert wird?

Ich hoffe, das ist einigermaßen verständlich

Viele Grüße!
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#2

AW: Multithread DLLs - gemeinsamer Speicher

  Alt 18. Apr 2014, 11:26
Sobald du vom gemeinsamen Zugriff auf Variablen in einer Multi-Thread-Umgebung sprichst, ist die Antwort pauschal immer "nicht threadsafe und fliegt dir irgendwann um die Ohren".

Ich kenne keinen Memory-Manager der Multi-Thread-Zugriffe auf den Speicher regelt.

Variablen sind niemals threadsafe. Nur Code kann threadsafe sein (oder eben nicht).
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#3

AW: Multithread DLLs - gemeinsamer Speicher

  Alt 18. Apr 2014, 12:43
Hm schade
Dann muss ich das also doch etwas "komplizierter" machen.
Bevor ich dann anfange: Wäre ein Aufbau wie im Anhang skizziert generell geeignet? (Das Synchronisieren des Puffers wird mit Synchronize ausgeführt).

Wenn ein Thread die Execute-Routine beendet hat, kann sie manuell erneut gestartet werden, ohne dass NICHT-Funktionsinterne Variablen, die im ersten Durchlauf verändert wurden, verloren gehen, oder? (Bin in Delphi noch nicht ganz drin in den Threads) Beispielsweise ein Objekt mit einer Datenbankverbindung kann wiederverwendet werden?
Miniaturansicht angehängter Grafiken
struktur.png  
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: Multithread DLLs - gemeinsamer Speicher

  Alt 18. Apr 2014, 13:58
Du musst das nicht synchronisieren, sondern nur zuverlässig gewährleisten, dass ein gleichzeitiger Zugriff nicht erfolgen kann. (z.B. Delphi-Referenz durchsuchenTCriticalSection)

Delphi-Quellcode:
unit Unit1;

interface

uses
  System.Classes,
  System.SyncObjs;

type
  TValueStore = class
  private
    FCS : TCriticalSection;
    FValues : TStringList;
    function GetValue( const Name : string ) : string;
    procedure SetValue( const Name, Value : string );
  public
    constructor Create;
    destructor Destroy; override;

    property Value[const Name : string] : string read GetValue write SetValue;
  end;

implementation

{ TValueStore }

constructor TValueStore.Create;
begin
  inherited;
  FCS := TCriticalSection.Create;
  FValues := TStringList.Create;
end;

destructor TValueStore.Destroy;
begin
  FValues.Free;
  FCS.Free;
  inherited;
end;

function TValueStore.GetValue( const Name : string ) : string;
begin
  FCS.Enter;
  try
    Result := FValues.Values[Name];
  finally
    FCS.Leave;
  end;
end;

procedure TValueStore.SetValue( const Name, Value : string );
begin
  FCS.Enter;
  try
    FValues.Values[Name] := Value;
  finally
    FCS.Leave;
  end;
end;

end.
Diese Klasse ist nun threadsafe, aber du musst auch aufpassen, dass der Zugriff auf die Instanz auch threadsafe ist und nicht von irgendwoher da wild neue Instanzen angelegt/freigegeben werden.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (18. Apr 2014 um 14:07 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#5

AW: Multithread DLLs - gemeinsamer Speicher

  Alt 18. Apr 2014, 15:13
Das sieht genau nach dem aus, was ich suche, danke!
Was meinst du denn mit dem letzten Satz genau, dass man nicht von irgendwoher neue Instanzen anlegen soll?!
Ich würde jetzt nach meinem Verständnis von dieser Klasse im Hauptthread eine Instanz erzeugen und den DLLs, welche in anderen Threads laufen, Pointer auf den Setter und Getter übergeben. Wäre das dann richtig oder ist das genau das, was es zu verhindern gilt?
  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 04:51 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