AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Thread arbeitet schneller wenn IDE aktiv ist. Warum?
Thema durchsuchen
Ansicht
Themen-Optionen

Thread arbeitet schneller wenn IDE aktiv ist. Warum?

Ein Thema von norwegen60 · begonnen am 20. Jan 2017 · letzter Beitrag vom 20. Jan 2017
Antwort Antwort
norwegen60

Registriert seit: 23. Dez 2007
Ort: Schwarzwald
505 Beiträge
 
Delphi 12 Athens
 
#1

Thread arbeitet schneller wenn IDE aktiv ist. Warum?

  Alt 20. Jan 2017, 09:11
Delphi-Version: 10 Seattle
Hallo zusammen,

ich habe folgenden Thread um mich etwas in die Thematik einzuarbeiten:

Delphi-Quellcode:
type
  TValues = Class
    dtTime : TDateTime;
    rForce,
    rTemperature,
    rHumidity : Real;
  End;


var
  Form1: TForm1;
  threadList1 : TThreadList;

...

procedure TForm1.FormCreate(Sender: TObject);
begin
  threadList1 := TThreadList.Create;
end;

procedure TForm1.Button2Click(Sender: TObject);
begin
  if (mythreadRunning = FALSE) then
  begin
    mythreadRunning:= TRUE;
    secondProcess := TMyThread.Create(True); { Create suspended--secondProcess does not run yet. }
    secondProcess.FreeOnTerminate := True; { You do not need to clean up after termination. }
    secondProcess.Priority := tpNormal; // Set the priority to lower than normal.
    secondProcess.Resume; { Now run the thread. }
  end
  else
    MessageDlg('This thread is still running. You are going to hurt yourself!',
      mtInformation, [mbOk], 0);
end;


procedure TMyThread.Execute;
var
  Values: TValues;
begin
  while(True) do
  begin
    if (Terminated) then
    begin
      mythreadRunning:= FALSE;
      exit;
    end;
    globalCount:= globalCount + 1;
    Values := TValues.Create;
    Values.dtTime := now;
    Values.rForce := globalCount;
    Values.rTemperature := globalCount/3;
    Values.rHumidity := globalCount/7;
    threadList1.Add(Values);
    Sleep(10);
  end;
  mythreadRunning:= FALSE;
end;
Das Seltsame:
  • Starte ich das Programm mit F9 in der Delphi IDE sehe ich anhand des Zeitstempels dass die Daten im 0.010 - 0.011s Intervall erzeugt werden
  • Starte ich die EXE bei laufender IDE im Explorer, werden die Daten ebenfalls im 0.010 - 0.011s Intervall erzeugt
  • Sobald ich Delphi beende erhöht sich der Intervall auf 0.015 -0.016s
  • Auch wenn ich die EXE ohne laufendes Delphi starte ist der Intervall 0.015 -0.016s
  • Dabei spielt es keine Rolle ob ich die EXE im DEBUG- oder om RELEASE-Mode erstellt habe.
  • Um sicher zu gehen, dass es nicht bei der Anzeige zu Nebeneffekte kommte, lasse ich mir die Daten erst anzeigen wenn der Erzeuger-Thead pausiert ist

Hat jemand eine Erklärung?

Danke
Gerd
Miniaturansicht angehängter Grafiken
threadtime.jpg  
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#2

AW: Thread arbeitet schneller wenn IDE aktiv ist. Warum?

  Alt 20. Jan 2017, 10:05
Das liegt daran, dass die IDE die Timer Resolution von Windows erhöht. Dadurch arbeitet Sleep bei sehr kleinen Werter genauer. Siehe auch MSDN-Library durchsuchentimeBeginPeriod.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
norwegen60

Registriert seit: 23. Dez 2007
Ort: Schwarzwald
505 Beiträge
 
Delphi 12 Athens
 
#3

AW: Thread arbeitet schneller wenn IDE aktiv ist. Warum?

  Alt 20. Jan 2017, 10:35
Habe mir die Kommentare in dem Link angeschaut und dann die SleepTime variabell gemacht.
Ergebnis:
Egal ob Sleep(1) oder Sleep(15) => Ist war 15-16 ms
ab 16 waren es dann 30-31 ms

Gibt es eine Möglichkeit die erhöhte Auflösung von Delphi beizubehalten?

Geändert von norwegen60 (20. Jan 2017 um 11:39 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

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

AW: Thread arbeitet schneller wenn IDE aktiv ist. Warum?

  Alt 20. Jan 2017, 13:38
Selbst timeBeginPeriod aufrufen?

Oder gar nicht Sleep benutzen und die Zeit selbst verwalten.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
norwegen60

Registriert seit: 23. Dez 2007
Ort: Schwarzwald
505 Beiträge
 
Delphi 12 Athens
 
#5

AW: Thread arbeitet schneller wenn IDE aktiv ist. Warum?

  Alt 20. Jan 2017, 14:24
Ja, OK. Hätte noch weiter nach dem timeBeginPeriod schauen sollen.
  Mit Zitat antworten Zitat
t.roller
(Gast)

n/a Beiträge
 
#6

AW: Thread arbeitet schneller wenn IDE aktiv ist. Warum?

  Alt 20. Jan 2017, 17:36
Siehe ClockRes v2.1

Nach der Änderung mit ClockRes kann man es mit folgendem Code überprüfen:
Delphi-Quellcode:
program SystemTimeAdjustment;

{$APPTYPE CONSOLE}

uses
// SysUtils, windows;
  System.SysUtils, Winapi.Windows;

  var a,b:DWORD; c:bool;

begin
  GetSystemTimeAdjustment(a,b,c);
  WriteLn('System time adjustment: '+FloatToStr(b / 10000)+' ms');
  WriteLn;
  Writeln('Press any key...');
  Readln;
end.

Geändert von t.roller (20. Jan 2017 um 17:54 Uhr)
  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 19:38 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