Модераторы: Poseidon, Snowy, bems, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Глюк дебагера Delphi 7 и 2005, Неправильно показывает знач. переменной 
:(
    Опции темы
LamerTM
Дата 16.1.2009, 12:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 97
Регистрация: 11.3.2006

Репутация: нет
Всего: 0



Код

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

  const GC = 25;
type

  TOG = array[1..GC] of Boolean;

  TForm1 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    procedure CF(c: TOG);
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;
  X: TOG;
implementation

{$R *.dfm}

procedure TForm1.CF(c: TOG);
var       i: Integer;
begin
          for i := 1 to GC do
          if c[i] then
          begin
          Caption := '';
          end;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
          X[1] := True;
          CF(X);
end;

end.



Брейкпоинт поставить на первую строку процедуры CF. Запустить, нажать Button1. Потом пару раз F7. Глюк дебагера такой: неправильно отображается значение переменной i  в процедуре CF во время выполнения цикла. Первое значение должно быть 1 (по факту и есть 1), но дебагер в хинте показывает i=25. На следующей итерации i=24, потом i=23, и т.д.

выглядит это прикольно. Например так:

user posted image

Такой глюк у меня в Delphi 7 и в Delphi 2005. Ну а вопрос: в каких делфях такого глюка нет (может в 2007?)

Это сообщение отредактировал(а) LamerTM - 16.1.2009, 12:10
PM MAIL   Вверх
bems
Дата 16.1.2009, 20:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 31
Всего: 88



это не глюк, а результат оптимизации. если в теле цикла сделать к примеру Caption := inttostr(i) то все встанет на место. А раз ты не используешь в теле цикла переменную, то компилятор вполне логично считает что тебе важно только количество итераций, но не последовательность значений


--------------------
Обижено школьников: 8
PM MAIL   Вверх
bems
Дата 22.1.2009, 20:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 31
Всего: 88



а этого-то я и не заметил
Цитата(LamerTM @  16.1.2009,  12:09 Найти цитируемый пост)
if c[i] then

Тогда присоединяюсь к топикстартеру, что бы это могло быть?


--------------------
Обижено школьников: 8
PM MAIL   Вверх
Romikgy
Дата 23.1.2009, 16:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель-программер
****


Профиль
Группа: Участник Клуба
Сообщений: 7326
Регистрация: 11.5.2005
Где: Porto Franco Odes sa

Репутация: 26
Всего: 146



не нравится убери оптимизацию!


PS по вопросу , процу легче циклы считать от числа к нулю , ибо ноль сразу устанавливат флаг нуля , т.е. без доп. телодвижений можно ноль или нет и сразу делать то что нужно 


--------------------
Владение русской орфографией это как владение кунг-фу — истинные мастера не применяют его без надобности. 
smile

PM   Вверх
bems
Дата 23.1.2009, 18:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 31
Всего: 88



Romikgy, то что ты говоришь мне известно, но помнится это поведение отключалось при любом использовании переменной в теле цикла. У топикстартера есть такое использование поэтому имхо это сомнительная оптимизация.


--------------------
Обижено школьников: 8
PM MAIL   Вверх
СЭНСЭЙ
Дата 12.8.2016, 04:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 432
Регистрация: 20.3.2006

Репутация: нет
Всего: нет



и что - так и не нашли решение?
беда в том, что значение переменной идет в обратном порядке при дебаге,
а если в цикле есть код типа 
Код

for i:=1 to 3 do begin
    s[i]:=false;

    if((src.eq[i].a<>0) AND (src.eq[i].b<>0)) then
       s[i]:=((src.eq[i].a*x-src.eq[i].b*y+src.eq[i].c>0)=src.eq[i].s);

то в условии подставляется 1 , а при вычислении - 3
это ни в какие ворота не лезет
какая может быть оптимизация?
Что с этим делать?
PM MAIL   Вверх
Alexeis
Дата 12.8.2016, 09:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Амеба
Group Icon


Профиль
Группа: Админ
Сообщений: 11743
Регистрация: 12.10.2005
Где: Зеленоград

Репутация: 109
Всего: 459



Цитата(СЭНСЭЙ @  12.8.2016,  05:03 Найти цитируемый пост)
какая может быть оптимизация?
Что с этим делать? 

  Эта оптимизация называется разворот цикла. Операция сравнения с нулем производится быстрее чем с некоторым числом, поэтому большинство компиляторов если видят что от порядка ничего не меняется, разворачивают цикл в обратном направлении.
Как там сейчас в новых делфях я не в курсе, но по идее когда проект компилируется в режиме дебага так не должно быть, но в старых версиях оптимизация включалась и в дебаге, так что приходилось ее отключать ключом {$O-} . Думаю это поможет. 


--------------------
Vit вечная память.

Обсуждение действий администрации форума производятся только в этом форуме

гениальность идеи состоит в том, что ее невозможно придумать
PM ICQ Skype   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Общие вопросы"
SnowyMetalFan
bemsPoseidon
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0796 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.