AGB  ·  Datenschutz  ·  Impressum  







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

dunkelgrüner Breakpoint ?

Ein Thema von EccoBravo · begonnen am 20. Okt 2005 · letzter Beitrag vom 21. Okt 2005
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von EccoBravo
EccoBravo

Registriert seit: 19. Okt 2004
Ort: Neuruppin
524 Beiträge
 
Delphi 2007 Architect
 
#1

dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 13:37
Neue Dummi-Frage:

Wundere mich, daß beim debuggen Programm am Haltepunkt nicht unterbrochen wird (obwohl es müßte).
Nun Beobachtung: In einigen Codestellen ist der Haltepunkt beim Setzen nicht rot sondern dunkelgrün. Oder ein gesetzter roter Haltepunkt wird beim Compilieren dunkelgrün. Das Programm hält dann an diesen Punkten nicht an. Was hat das auf sich?
(BD7 Enterprise)

Vielen Dank

E. B.
  Mit Zitat antworten Zitat
Benutzerbild von Treffnix
Treffnix

Registriert seit: 25. Jun 2003
Ort: AC
740 Beiträge
 
Delphi 7 Professional
 
#2

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 13:40
grün bedeutet, dass das Programm an dieser Zeile niemals nicht vorbeilaufen wird. In der Regel, weil du die Funktion nirgends benutzt oder weil du ne Zeile ausgewählt hast, in der kein Befehl steht. Evtl. wurds auch wegoptimiert.

Wenn du z.B. bei

Delphi-Quellcode:
showmessage( 'Ich wollte nur mal Hallo sagen: '#13#10 +
             'Hallo' );
den Breakpoint auf die zweite Zeile setzen würdest, würde er dort auch nicht anhalten
  Mit Zitat antworten Zitat
Mattin

Registriert seit: 4. Sep 2003
72 Beiträge
 
Delphi 7 Professional
 
#3

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 13:42
Zitat von EccoBravo:
Neue Dummi-Frage:

Wundere mich, daß beim debuggen Programm am Haltepunkt nicht unterbrochen wird (obwohl es müßte).
Nun Beobachtung: In einigen Codestellen ist der Haltepunkt beim Setzen nicht rot sondern dunkelgrün. Oder ein gesetzter roter Haltepunkt wird beim Compilieren dunkelgrün. Das Programm hält dann an diesen Punkten nicht an. Was hat das auf sich?
(BD7 Enterprise)
E. B.
Steht der Breakpoint vielleicht auf einer Abfrage IF/ WHILE / FOR oder so ??
Mit freundlichen Grüßen
Mattin

http://www.martin-karwoth.de
  Mit Zitat antworten Zitat
Benutzerbild von jim_raynor
jim_raynor

Registriert seit: 17. Okt 2004
Ort: Berlin
1.251 Beiträge
 
Delphi 5 Standard
 
#4

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 13:42
Das bedeutet, dass an dieser Stelle kein Ausführbarer Code ist. Zu erkennen an dem kleinen blauen Punkt beim Starten in Delphi.

An diesen Stellen kann dann auch nicht angehalten werden, da dort kein ausführbarer Code ist. Eine Ursache kann zum Beispiel der Optimierer sein, der Teile des Codes wegoptimiert hat, weil diese einfach nicht benötigt werden oder ganze Prozeduren überhaupt nicht verwendet werden.

Falls das "Problem" in einer ganzen Unit auftritt, liegt es meistens an fehlerhaften Verzeichnissen.
Christian Reich
Schaut euch mein X-COM Remake X-Force: Fight For Destiny ( http://www.xforce-online.de ) an.
  Mit Zitat antworten Zitat
Benutzerbild von EccoBravo
EccoBravo

Registriert seit: 19. Okt 2004
Ort: Neuruppin
524 Beiträge
 
Delphi 2007 Architect
 
#5

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 14:41
Vorgestellt habe ich mir das mit dem ausführbaren Code auch so,
aber so ganz glaube ich das nicht, denn die blauen Punkte stehen nicht vor Kommentarzeilen, und END-Zeilen. Dafür stehen sie ganz willkürlich innerhalb von BEGIN...END-Bereichen (mal ja mal nicht) vor ausführbaren Zeilen.
Und dann noch
färben sich beim Kompilieren auch mal die Haltepunkte der nicht blau punkteten Zeilen dunkelgrün und die Haltepunkte der Blau bepunkteten Zeilen bleiben rot. Also alles ziemlich unregelmäßig. Anhalten tut der Debugger in diesen Fällen nie, obgleich er müßte.

So und nun zum Optimizer,
Gehört habe ich auch schon so etwas, Mein Eindruck ist, daß dieser Optimizer ganze Quelltextpassagen einfach weggelassen hat. Ich hatte schon früher so etwas beobachtet, mich geärgert/ gewundert. Ohne diesen Optimizer zu verstehen habe ich mir geholfen, indem ich ganze Kode-Passagen umgestellt hatte, retundante Bedingungen programmiert habe usw. Zufrieden bin ich damit aber überhaupt nicht! Die Transparenz der Programme geht damit unweigerlich verloren.
Nun, kann mir jemand verraten, wie ich auf das Verhalten des Optimizers Einfluß nehmen kann?
Ich will den Kram endlich begreifen.

Am Rande sei mir wegen meiner gehäuft dummen Fragen verziehen. Als Autodidakt bin ich halt immer noch ein Amateur, obgleich ich auf 20-jährige, teils recht pragmatische Erfahrungen zurückblicken kann.
Ursprünglich als neue Dummie-Frage tituliert, sei diese Frage ernst.

Vielen Dank, E. B.
  Mit Zitat antworten Zitat
Benutzerbild von Treffnix
Treffnix

Registriert seit: 25. Jun 2003
Ort: AC
740 Beiträge
 
Delphi 7 Professional
 
#6

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 14:54
Menü Projekt -> Optionen -> Häkchen bei Optimierung weg

Bevor du dann die endgültige Programmversion compilierst, wenn alle Fehler beseitigt sind, solltest du den Haken aber wieder setzen.

*edit*
Wäre vielleicht ganz hilfreich, wenn du mal ein paar Zeilen Beispielcode posten würdest, wo ein Breakpoint nicht funktioniert, obwohl er es deiner Meinung nach müsste.
  Mit Zitat antworten Zitat
Benutzerbild von EccoBravo
EccoBravo

Registriert seit: 19. Okt 2004
Ort: Neuruppin
524 Beiträge
 
Delphi 2007 Architect
 
#7

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 15:18
Na klar:
Delphi-Quellcode:
...
if <bedingung 1> then
              begin
                  <anweisung 1a>
                  <anweisung 1b>
              end
else if <bedingung 2> then
              begin
                  <anweisung 2a>
                  <anweisung 2b>
              end
...
etwa 50 x ( else if <bedingungn> )
...
else if <bedingung n+1> then
              begin
                  <anweisung n+1a> // ab hier finktionieren die Braekpoints nicht mehr
                  <anweisung n+1b>
              end
else if <bedingung n+2> then
              begin
                  <anweisung n+2a>
                  <anweisung n+2b>
              end
...
else if <bedingung n+m> then // n+m = ca.100
              begin
                  <anweisung n+ma>
                  <anweisung n+mb>
              end

else begin
     end;

...
Egal was sich dahinter verbirgt, alle Anweisungen müßten potentiell erreichbar sein, also die Breakpoints rot bleiben.
Ob sie dann zur Laufzeit auch immer erreicht werden ist eine andere Sache.

Bei mir ist es verrückter weise so, daß eine <anweisung..a> blaubepunktet und die <anweisung..b> im gleichen BEGIN..END Bereich unbepunktet ist bzw. umgekehrt.
Oder, innerhalb eines BEGIN..END Bereiches bleibt eine <anweisung..>-zeile rot und die andere dunkelgrün.
Entweder beide rot oder beide grün, so sehe ich das.

Das wäre meine aktuelle Problemstelle,

Vielen Dank, wenn Du / Ihr etwas dazu wißt

E. B.
  Mit Zitat antworten Zitat
Benutzerbild von Treffnix
Treffnix

Registriert seit: 25. Jun 2003
Ort: AC
740 Beiträge
 
Delphi 7 Professional
 
#8

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 15:33
Bei so einem Konstrukt wird das vermutlich an der Optimierung liegen. Übrigens: Optimierung bedeutet nicht, dass er das auch wirklich löscht. Es wird nur zu einem günstigeren Konstrukt umgestellt und ist deshalb oft nicht mehr debugbar, da es in deinem Quelltext keine echte Entsprechung des Maschinencodes mehr gibt, auf die der Debugger verweisen könnte. Haste das ganze mal mit abgeschalteter Optimierung versucht?
  Mit Zitat antworten Zitat
Oxmyx

Registriert seit: 21. Sep 2004
499 Beiträge
 
#9

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 15:46
Zeig mal ein konkretes Quellcode-Beispiel, das bei dir nicht wie erhofft funktioniert. An deinem Pseudocode kann man so etwas nicht unbedingt erkennen.
  Mit Zitat antworten Zitat
chris_k

Registriert seit: 23. Aug 2004
Ort: Rosenheim
2 Beiträge
 
#10

Re: dunkelgrüner Breakpoint ?

  Alt 20. Okt 2005, 16:16
Es wird nicht nur Code wegoptimiert der nicht erreichbar ist, sondern auch überflüssiger Code. Zur Verdeutlichung mal das folgende (zugegebenermaßen recht sinnlose) Beispiel:

Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var a,b:integer;
begin
  a:=1;
  b:=2;
  showmessage('a='+IntToStr(a));
end;
Die Zeile b:=2; ist nicht notwendig da b nie verwendet wird, deshalb wird sie wegoptimiert.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 06:06 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