TreeView странность.

Вопросы программирования и использования среды Lazarus.

Модератор: Модераторы

Re: TreeView странность.

Сообщение zub » 03.09.2017 00:16:46

>>Вот это неправильно:
Слышал звон и не знал где он. Что тут неправильно?
На этом форуме всё топится во флейме, а непонимающие люди с умным видом порют чушь((
zub
долгожитель
 
Сообщения: 2380
Зарегистрирован: 14.11.2005 23:51:26

Re: TreeView странность.

Сообщение wofs » 03.09.2017 00:21:01

zub писал(а):Цените время форумчан

Убрал, в сообщении выше и в первом сообщении, в самом низу.

Добавлено спустя 5 минут 40 секунд:
vitaly_l писал(а):И покажите, в своём примере, как вы чистите pointer,

А как мне их почистить? Посмотрите, пожалуйста, примеры в сообщении выше.
Аватара пользователя
wofs
постоялец
 
Сообщения: 339
Зарегистрирован: 05.10.2009 10:16:55
Откуда: Астрахань

Re: TreeView странность.

Сообщение vitaly_l » 03.09.2017 08:25:07

wofs писал(а):А как мне их почистить? Посмотрите, пожалуйста, примеры в сообщении выше.

Посмотрел, но Вы вернулись к изначальному варианту и опять ничего не создаёте - значит и чистить Вам ничего не надо!

zub писал(а):На этом форуме всё топится во флейме, а непонимающие люди с умным видом порют чушь((
Слышал звон и не знал где он. Что тут неправильно?

Когда он подключал схему с использованием new(), то старая схема - переставала работать, т.к. адрес был уже правильный и не совпадал с адресом из ответа SQL. И поэтому он не мог заполнить дерево, т.к. сравнение всегда возвращало false.

Я так понимаю сейчас всё работает и делает правильно? И автор при этом, ничего не чистит? Верно?
Золотое правило: Если работает - не трогай!

PS: Я в примерах не нашёл использования функции new(), соответственно: постольку, поскольку - Вы ничего не создавали, то и удалять ничего ненужно. Соответственно "самодельная" функция Clear(); лишняя и более того неправильная, т.к. ничего не чистит, разве что data присваивается nil.

.
Последний раз редактировалось vitaly_l 03.09.2017 08:35:38, всего редактировалось 1 раз.
Аватара пользователя
vitaly_l
долгожитель
 
Сообщения: 3333
Зарегистрирован: 31.01.2012 16:41:41

Re: TreeView странность.

Сообщение olegy123 » 03.09.2017 08:33:44

zub писал(а):
olegy123 писал(а):
wofs писал(а):Просто в коде процедуру
Код: Выделить всё
FillTree();
буду вызывать через QueueAsyncCall

WTF?
Зачем?
Мултипоточность нужно применять там где это необходимо - иначе решения задачи усложняется в разы.
Вместо правильности кода будете ловить эксепшены в неожиданных местах.
У вас было проблема в утечке памяти. Продолжали работать с зомби классом.

Какая тут мультипоточность? это отложенное выполнение процедуры

Приношу свои извинения. Спутал с операторами в VC++ с многопоточными асинхронными запросами.

Добавлено спустя 10 минут 15 секунд:
zub писал(а):>>Вот это неправильно:
Слышал звон и не знал где он. Что тут неправильно?
На этом форуме всё топится во флейме, а непонимающие люди с умным видом порют чушь((

Нужен модератор, с академическим знанием, с огромным просветительским опытом и званием не ниже действующего члена академии наук СССР. С купленными местами в РФ категорически не брать.
Обязательно, чтобы был фанат одной школы - других люто ненавидел. Только его флейм был "истиной в последней инстанции".
olegy123
энтузиаст
 
Сообщения: 898
Зарегистрирован: 25.02.2016 12:10:20

Re: TreeView странность.

Сообщение wofs » 03.09.2017 10:59:04

vitaly_l писал(а):Я в примерах не нашёл использования функции new(), соответственно: постольку, поскольку - Вы ничего не создавали, то и удалять ничего ненужно.

Изначально так и было.
vitaly_l писал(а):Соответственно "самодельная" функция Clear(); лишняя и более того неправильная, т.к. ничего не чистит, разве что data присваивается nil.

А ее и нет ныне...
vitaly_l писал(а):Я так понимаю сейчас всё работает и делает правильно? И автор при этом, ничего не чистит? Верно?
Золотое правило: Если работает - не трогай!

Правильно, через QueueAsyncCall.

Спасибо всем.

p.s. разве, что в примерах память, выделенную под массив забыл освободить при закрытии приложения.
Аватара пользователя
wofs
постоялец
 
Сообщения: 339
Зарегистрирован: 05.10.2009 10:16:55
Откуда: Астрахань

Re: TreeView странность.

Сообщение vitaly_l » 03.09.2017 11:14:05

wofs писал(а):Правильно, через QueueAsyncCall.
Clear(); А ее и нет ныне...

В этом-то весь и секрет. Постольку поскольку, вы уже не используете "самописную" Clear(), значит вы уже не используете и Items[i].Free;, соответственно как выразился Zub - вы уже "не рубите всё дерево на корню", т.к. отсутствует запрос Items[i].Free;.

Тогда зачем Вы запускаете QueueAsyncCall? А?

Функцию, QueueAsyncCall - вам предложили использовать именно из-за Clear() и Items[i].Free; которая в ней.

Но теперь когда их нет, зачем QueueAsyncCall ?
Аватара пользователя
vitaly_l
долгожитель
 
Сообщения: 3333
Зарегистрирован: 31.01.2012 16:41:41

Re: TreeView странность.

Сообщение wofs » 03.09.2017 13:32:31

vitaly_l писал(а):Но теперь когда их нет, зачем QueueAsyncCall ?

Потому, что я использую
Код: Выделить всё
Items.Clear; //очищаем дерево

в процедуре FillTree();
И без QueueAsyncCall я получаю ту же проблему (не ошибку!), из-за которой сюда пришел.
Скажите, какая у вас Ос, я скопмилирую оба проекта под нее и вы посмотрите, наконец, что за проблема.
Аватара пользователя
wofs
постоялец
 
Сообщения: 339
Зарегистрирован: 05.10.2009 10:16:55
Откуда: Астрахань

Re: TreeView странность.

Сообщение vitaly_l » 03.09.2017 13:46:42

wofs писал(а):пытаетесь тыкнуть меня носом в мои ошибки

Так вы убрали свою самодельную Clear();? Значит оно всё таки, действительно было лишним?

Значит я, уже - не зря потратил своё время, т.к. кроме Вас это читают и другие. Надеюсь они смогут понять разницу между адресом на глобальную переменную(как в новом примере) и адресом на локальную переменную(как в старом примере). И надеюсь они смогут понять почему адрес данный на локальную переменную - становится зомби адресом, после окончания работы функции, в следствии чего и появляются Ваши "странные" глюки. И такое решение (с помощью костыля в виде QueueAsyncCall, но без понимания сути проблемы ) уже - не приведёт к сбою АЭС или падению самолёта, если они подсмотрят это решение в этом топике.


.
Последний раз редактировалось vitaly_l 03.09.2017 13:53:48, всего редактировалось 1 раз.
Аватара пользователя
vitaly_l
долгожитель
 
Сообщения: 3333
Зарегистрирован: 31.01.2012 16:41:41

Re: TreeView странность.

Сообщение wofs » 03.09.2017 13:53:39

vitaly_l писал(а):в следствии чего и появляются Ваши "странные" глюки.


Глюки есть и без моих самописных функций очистки.

Добавлено спустя 39 секунд:
laz_tree_0.png


Зесь красным "Узел 11" читать как "Узел 7":
laz_tree_1.png
У вас нет необходимых прав для просмотра вложений в этом сообщении.
Последний раз редактировалось wofs 03.09.2017 13:55:38, всего редактировалось 2 раз(а).
Аватара пользователя
wofs
постоялец
 
Сообщения: 339
Зарегистрирован: 05.10.2009 10:16:55
Откуда: Астрахань

Re: TreeView странность.

Сообщение vitaly_l » 03.09.2017 13:54:34

wofs писал(а):Глюки есть и без моих самописных функций очистки.

И надеюсь они смогут понять почему адрес данный на локальную переменную - становится зомби адресом. И такое решение (с помощью костыля в виде QueueAsyncCall, но без понимания сути проблемы ) уже - не приведёт к сбою АЭС или падению самолёта, если они подсмотрят это решение в этом топике.
Последний раз редактировалось vitaly_l 03.09.2017 13:58:19, всего редактировалось 1 раз.
Аватара пользователя
vitaly_l
долгожитель
 
Сообщения: 3333
Зарегистрирован: 31.01.2012 16:41:41

Re: TreeView странность.

Сообщение wofs » 03.09.2017 13:57:28

vitaly_l писал(а):И такое решение (с помощью костыля в виде QueueAsyncCall, но без понимания сути проблемы ) уже - не приведёт к сбою АЭС или падению самолёта, если они подсмотрят это решение в этом топике.

Однако, предложенное вами решение в виде создания своих указателей не заработало и дерево не заполнилось.
Аватара пользователя
wofs
постоялец
 
Сообщения: 339
Зарегистрирован: 05.10.2009 10:16:55
Откуда: Астрахань

Re: TreeView странность.

Сообщение vitaly_l » 03.09.2017 13:59:48

wofs писал(а):Однако, предложенное вами решение в виде создания своих указателей не заработало и дерево не заполнилось.

Потому что, помимо исправленного, нужно было ещё и вот это исправить:
Код: Выделить всё
if Tree1.Items.Item[i].Data = Pointer(FieldByName(idParent).asInteger)

и прочитайте уже про pointеr и узнайте: что это такое и чем оно отличается от переменной?
И попробуйте, понять в каких случаях зомби адрес может совпадать с новым адресом и выдаваться такой глюк как у Вас, именно при вышеприведённом запросе: if Tree1.Items.Item[i].Data = Pointer(FieldByName(idParent).asInteger) then...

На этом ликбезу конец.
vangamode := off;


.
Последний раз редактировалось vitaly_l 03.09.2017 14:13:01, всего редактировалось 1 раз.
Аватара пользователя
vitaly_l
долгожитель
 
Сообщения: 3333
Зарегистрирован: 31.01.2012 16:41:41

Re: TreeView странность.

Сообщение wofs » 03.09.2017 14:10:01

vitaly_l писал(а):и прочитать уже про pointеr

Я понимаю это так - переменная, которая хранит адрес на ячейку памяти.
Попробую еще раз переписать пример с вашими правками.
Аватара пользователя
wofs
постоялец
 
Сообщения: 339
Зарегистрирован: 05.10.2009 10:16:55
Откуда: Астрахань

Re: TreeView странность.

Сообщение vitaly_l » 03.09.2017 14:16:28

wofs писал(а):хранит адрес на ячейку памяти

Когда вы сравниваете номер ячейки if Tree1.Items.Item[i].Data = Pointer(FieldByName(idParent).asInteger) then... то сравниваете его с зомби ячейкой, и поэтому при СЛУЧАЙНОМ совпадении номера ячейки - появляется Ваш якобы глюк. Независимо от того что в ячейке лежит. И поэтому выскакивает запись из ячейки, которая была при предыдущих запросах. Постольку поскольку совпадают номера ячеек.

После этого вы создаёте ещё один Pointer(FieldByName(idNode).asInteger)... Который не всегда может равняться тому что при запросе if then, т.к. функция asInteger локальная и может каждый раз - возвращать разное значение номера ячеек, даже если запросы идут подряд.

.
Аватара пользователя
vitaly_l
долгожитель
 
Сообщения: 3333
Зарегистрирован: 31.01.2012 16:41:41

Re: TreeView странность.

Сообщение wofs » 03.09.2017 14:35:45

vitaly_l писал(а):Я пробовал переписать
Код: Выделить всё
if Items.Item[iTree].Data = Pointer(integer(dbArr[i + 1, 1])) then

на
Код: Выделить всё
PtrToInt2^ := integer(dbArr[i + 1, 1]);

        if Items.Item[iTree].Data = PtrToInt2 then



Но получил указатель, который указывает черте куда.

Нашел ошибку!

Добавлено спустя 9 минут 16 секунд:
Функция заполнения теперь выглядит так:
Код: Выделить всё
procedure TForm1.FillTree(); // заполнение дерева
var
  i, iTree: integer;
  ptrToInt2 : ^Integer;
begin
  New(ptrToInt2);

  with Tree1 do
  begin
    BeginUpdate;
    Items.Clear; //очищаем дерево

    ptrToInt2^ := integer(dbArr[0, 0]);
  //  node.data := ptrToInt2; // или так @ptrToInt2; - зависит от директивы  Zub - писал выше

    Items.AddObject(nil, dbArr[0, 2], ptrToInt2);

    // добавляем корневой объект

    for i := 0 to Length(dbArr) - 2 do // перебираем в цикле
    begin

      if i = 0 then
        Log('iTree= ' + IntToStr(0) + ' Node= ' + string(dbArr[i, 0]) + ' Parent= ' +
          string(dbArr[i, 1]) + ' Name= ' + string(dbArr[i, 2]));

      iTree := 0;
      while iTree < Items.Count do
      begin

        PtrToInt2^ := integer(dbArr[i + 1, 1]);

        if Items.Item[iTree].Data = PtrToInt2 then
        begin

          Log('iTree= ' + IntToStr(iTree) + ' Node= ' + string(dbArr[i + 1, 0]) +
            ' Parent= ' + string(dbArr[i + 1, 1]) + ' Name= ' + string(dbArr[i + 1, 2]));

          ptrToInt2^ := integer(dbArr[i+1, 0]);

          Items.AddChildObject(Items.Item[iTree],
            string(dbArr[i + 1, 2]), ptrToInt2);  // добавляем дочерние объекты
          break;
        end;
        Inc(iTree);
      end;

    end;

    Items[0].Expand(True);
    EndUpdate;
    Dispose(ptrToInt2);
  end;
end;       

Дерево заполняется, но неверно:
laz_tree_2.png

Проблема все-таки опять в сравнении:
Код: Выделить всё
        PtrToInt2^ := integer(dbArr[i + 1, 1]);

        if Items.Item[iTree].Data = PtrToInt2 then
У вас нет необходимых прав для просмотра вложений в этом сообщении.
Аватара пользователя
wofs
постоялец
 
Сообщения: 339
Зарегистрирован: 05.10.2009 10:16:55
Откуда: Астрахань

Пред.След.

Вернуться в Lazarus

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 5

Рейтинг@Mail.ru