AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Rechenintensive Funktion verhindert Ausführung
Thema durchsuchen
Ansicht
Themen-Optionen

Rechenintensive Funktion verhindert Ausführung

Ein Thema von Yheeky · begonnen am 13. Dez 2005 · letzter Beitrag vom 13. Dez 2005
Antwort Antwort
Yheeky

Registriert seit: 7. Jun 2002
1.339 Beiträge
 
#1

Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 01:02
Hi!

Ich habe ein Ereignis, welches OnConnect aufruft. In OnConnect steckt eine rechenintensive Funktion. Mein Problem ist nun, dass wenn der Befehl Disconnect aufgerufen wurde, der Code in OnDisconnect nicht ausgeführt wird, da das Programm noch mit der rechenintensiven Funktion in OnConnect beschäftigt ist. Was kann ich da machen? Muss ich mit Application.ProcessMessages arbeiten? Wenn ja, wo muss ich das genau platzieren?
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 01:10
Ich würde mit Threads arbeiten, das ist die saubere Löung und auch die einzige, wenn du keine Schleife hast, in der du [u]ProcessMessages aufrufen könntest.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Yheeky

Registriert seit: 7. Jun 2002
1.339 Beiträge
 
#3

Re: Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 01:25
Okay, danke für den Hinweis. Habe eben mal zum Testen try...finally probiert und es scheint auch zu funktionieren...danke trotzdem!
  Mit Zitat antworten Zitat
Benutzerbild von yankee
yankee

Registriert seit: 10. Mär 2004
1.134 Beiträge
 
Lazarus
 
#4

Re: Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 01:26
Zitat von Luckie:
Ich würde mit Threads arbeiten, das ist die saubere Löung und auch die einzige, wenn du keine Schleife hast, in der du ProcessMessages aufrufen könntest.
Es macht nicht so den Eindruck, als wäre unser Threadstarter da scharf drauf .

Ok, also es gibt schon eine Möglichkiet das mit Application.ProcessMessages zu lösen. Dafür musst du ertsmal verstehen, was diese Funktion macht:
Sie pausiert die Funktion, aus der sie aufgerufen wurde und führt erstmal alle anderen anstehenden Aufgaben aus. Dann führt sie die erste Funktion wieder aus. Also stell dir zum Beispiel vor, du hast deine Rechenintensive Funktion und einen Abbrechen Button:
Delphi-Quellcode:
var abbrechen: Boolean; //globale Variable
procedure AbbrechenClick; //wird ausgeführt, wenn du auf abbrechen klickst
begin
    abbrechen :=true;
end;

procedure RechneIntensiv;
var i:integer;
begin
    for i:=0 to 10000 do
    begin
         if abbrechen then exit;
        //hier jede Menge rechenzeug
    end;
end;
Klingt wie eine verdammt gute Idee, ne? Aber wenn du es umsetzt, fällt auf, dass wenn du auf den Button klickst, dein Klick in einer Art "Warteschleife" landet und erst ausgeführt wird, wenn dein Programm mit seiner momentanen Aufgabe (RechneIntensiv) fertig ist. Und hier kommt Application.ProcessMassages ins Spiel:
Du ändert die Funktion RechneIntensiv so ab:
Delphi-Quellcode:
procedure RechneIntensiv;
var i:integer;
begin
    for i:=0 to 10000 do
    begin
        application.processMessages; //<--hier ist die Änderung!
        if abbrechen then exit;
        //hier jede Menge rechenzeug
    end;
end;
Jetzt wir das Programm bei jedem Schleifendurchlauf die procedure anhalten, gucken ob andere aufgaben anstehen und diese ggf. erstmal ausführen. Sollte funzen. Jetzt muss du das ganze nurnoch auf dein Problem abändern....

EDIT: Was, du hast das mit try-final geschafft? Wie das denn?
Letzter Tipp: Drogen. Machen zwar nicht glücklich, geben einem aber wenigstens das Gefühl glücklich zu sein.

Have a lot of fun!
  Mit Zitat antworten Zitat
Yheeky

Registriert seit: 7. Jun 2002
1.339 Beiträge
 
#5

Re: Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 01:58
Erstmal vielen Dank Yankee für deine Erklärung. Endlich weiss ich jetzt wie ProcessMessages funktioniert, das war mir wirklich immer ein Rätsel. Nochmals vielen Dank!

Also ich muss ja kein Geheimnis machen, um was es genau geht Ich muss allerdings dazu sagen, dass das Problem wohl doch einen etwas anderen Ursprung hat:
Ich programmiere ja an einem ISDN Anrufmonitor. Wenn ein Anruf eingeht, wird OnIncomingCall aufgerufen. Hier ist nun eine Abfrage drin, ob der Anrufer im Telefonbuch steht und unter anderem eben auch, ob der Anrufer einen speziellen Anrufklingelton hat. Wenn ja wird dieser abgespielt.
Wurde nun ein eingehender Anruf erkannt, der allerdings sofort wieder getrennt wird/wurde, so hat er OnDisconnect nicht aufgerufen. In OnDisconnect stand nämlich u.a. dass die Klingeltonwiedergabe gestoppt werden soll. Auch andere Funktionen wie z.B. Label1.Caption := 'Test'; wurden NICHT aufgerufen.

Nun gab es 2 Auffälligkeiten:
  • Wenn ich den Befehl "Klingeltonwiedergabe stoppen" in OnDisconnect auskommentiert hatte, funktionierte es.
    und
  • wenn ich eine ShowMessage an den Anfang von der OnDisconnect Prozedure stellte, funktionierte auch alles.

Da beides ja keine zufriedenstellende Lösung für mein Problem war, habe ich try...finally probiert und das hat bei meinen ersten Tests funktioniert.

Nun, bin ich gespannt auf eure Erkläerungen
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#6

Re: Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 03:34
Zitat von Yheeky:
Erstmal vielen Dank Yankee für deine Erklärung. Endlich weiss ich jetzt wie ProcessMessages funktioniert, das war mir wirklich immer ein Rätsel. Nochmals vielen Dank!
Hilfe lesen bildet:
Zitat:
Description

Call ProcessMessages to permit the application to process messages that are currently in the message queue. ProcessMessages cycles the Windows message loop until it is empty, and then returns control to the application.

Note: Neglecting message processing affects only the application calling ProcessMessages, not other applications. In lengthy operations, calling ProcessMessages periodically allows the application to respond to paint and other messages.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
runger
(Gast)

n/a Beiträge
 
#7

Re: Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 06:35
Hallo,

Zitat:
Sie pausiert die Funktion, aus der sie aufgerufen wurde und führt erstmal alle anderen anstehenden Aufgaben aus. Dann führt sie die erste Funktion wieder aus.
das ist so nicht ganz korrekt:
sie prüft lediglich, ob in der messagequeue ( deine application betreffend ) etwas steht und führt die Anforderungen aus die dort stehen. Das Ganze gilt nur application-weit.
Das geht aus deiner Aussage nicht eindeutig hervor.

Rainer
  Mit Zitat antworten Zitat
Yheeky

Registriert seit: 7. Jun 2002
1.339 Beiträge
 
#8

Re: Rechenintensive Funktion verhindert Ausführung

  Alt 13. Dez 2005, 19:30
Zitat von runger:
Hallo,

Zitat:
Sie pausiert die Funktion, aus der sie aufgerufen wurde und führt erstmal alle anderen anstehenden Aufgaben aus. Dann führt sie die erste Funktion wieder aus.
das ist so nicht ganz korrekt:
sie prüft lediglich, ob in der messagequeue ( deine application betreffend ) etwas steht und führt die Anforderungen aus die dort stehen. Das Ganze gilt nur application-weit.
Das geht aus deiner Aussage nicht eindeutig hervor.

Rainer
Gut, danke Rainer für die Richtigstellung Ich habe das aber auch schon so verstanden, auch wenn er´s nicht 100%ig korrekt ausgedrückt hat *g*.
  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 22:20 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