Hi,
ich bin gezwungen, in meiner Anwendung Application.ProcessMessages an einigen Stellen zu eliminieren,
da genau dieses für sporadische Abstürze der DevExpress QuantumGrid beim Destroy von Formularen sorgt.
Bisher hatte ich das Schließen der Anwendung so:
Alle Formulare schließen;
Application.ProcessMessages;
Disconnect von der
DB;
oder Wechsel der Datenbank:
Alle Formulare schließen;
Application.ProcessMessages;
ReConnect von der
DB;
Jetzt habe ich mir versuchsweise eine MethodenListe erstellt, welche ich z.B. bei Wechsel der
DB füttere:
In MethodenListe Methode für Schließen aller Formulare;
In MethodenListe Methode für ReConnect;
Delphi-Quellcode:
procedure TFRMMain.DoChangeConnection(Sender: TObject);
Var
AMethod: TNotifyEvent;
begin
// Datenbank wechseln
Application.ProcessMessages;
if CanCloseEx then
begin
// Alles Fenster zu
AMethod := CloseAllModules;
FMethodList.Add(TMethod(AMethod));
// neu verbinden
AMethod := ChangeConnection;
FMethodList.Add(TMethod(AMethod));
end;
end;
procedure TFRMMain.UpdateActions;
begin
inherited;
if (FMethodList <> nil) then
HandleNextMessage;
end;
procedure TFRMMain.HandleNextMessage;
Var
AEvent: TNotifyEvent;
begin
// immer ein Event nach FIFO abarbeiten
if (FMethodList.Count <> 0) then
begin
AEvent := TNotifyEvent(FMethodList[0]);
FMethodList.Remove(TMethod(AEvent));
TNotifyEvent(AEvent)(Self);
end;
end;
In der überschriebenen Methode UpdateActions der Form (welche ja vom Idle der App abhängig ist) rufe ich nun eine Methode auf, welche immer die erste Methode aus der Methodenliste holt, den Eintrag aus der Liste entfernt und die Methode ausführt.
Der Wechsel der BD funktioniert erst mal so weit. Aber das Schließen wird schon komplizierter, da ich das im CloseQuery des Forms abfange und es wahrscheinlich gar nicht mehr zum Aufruf von UpdateActions führt.
Gibt es eine elegantere Lösung?
Ideal wäre etwas in der Art:
Formular schließen;
Warten, bis es komplett zerstört ist;
Und jetzt weiter;
Aber das eben ohne Application.ProcessMessages...
Das Warten ist notwendig, da ich in den Formularen z.B. im BeforeDestruction noch alle möglichen Einstellungen in die
DB schreibe.
Warte ich nicht, ist die
DB-Verbindung gekappt, während die Forms noch fleißig versuchen, ihre Einstellungen in die
DB zu schreiben.
Ich hoffe, mein Problem einigermaßen verständlich dargestellt zu haben.
Ich brauche jetzt nicht den Hinweis, mich bitte an den Herstelle zu wenden etc.
Ich brauche einen Workaround und möchte einfach nur wissen, ob und wie es evtll. besser geht.
Danke, Frank