Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.12.05;
Скачать: CL | DM;

Вниз

Удаление ветки с дочерними элементами TTreeView   Найти похожие ветки 

 
TechnoDreamer ©   (2004-11-22 02:22) [0]

Надо функция удаляющая TTreeNode со всеми дочерними элементами. Причем она должна быть не рекурсивной и удалять каждый элемент по одному (потому что вместе с элементом надо удалять и связанные с ним данные). Поможет кто-нибуть с этим?


 
jack128 ©   (2004-11-22 02:30) [1]

TechnoDreamer ©   (22.11.04 2:22)
Причем она должна быть не рекурсивной

Чем вызвано это ограничение ? В принципе рекурсию можно развернуть, но в плане кодирования это на порядок сложнее.


 
TechnoDreamer ©   (2004-11-22 02:36) [2]

Знаю, что сложнее, потому и спрашиваю, рекурсивная есть. Работает с ошибками (идет работа с базой данных через ADO) и медленно. Т.е. на небольших ветках всё нормально, а с большими пробела, и именно с базой, при чём ошибка именно ADO.


 
jack128 ©   (2004-11-22 03:52) [3]

Вообще лудше почитать теорию на этот счет, а вот вот что надумал.
Алгоритм беру из головы, ни разу на практике не применял, но идею, думаю, подскажет..

label lb1, lb2;
begin
//Заводишь стек для всех переменных, используемых в процедуре.

lb1:
 //выполняешь код, до рекурсивного вызова.

 // вместо рекурсивного вызова делаешь:
 //      кладешь все переменные в стек
 //      и подменяешь входные параметры на новые
 //      goto lb1;
lb2:
 //...

 //вместо завершения процедуры
 if not стек_переменных_пустой then
 begin
   //извлекаешь переменные из стека
   goto lb2;
 end;
end;

Но лудше по подробнее задачу опиши.. Может удастся оптимизировать так, что и рекурсия прокатит.

зы: а с чего ты вообще решил, что проблема именно в рекурсии???



Страницы: 1 вся ветка

Текущий архив: 2004.12.05;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.044 c
8-1094119325
Hman
2004-09-02 14:02
2004.12.05
Громкость в WinAmp е


4-1098200620
crio
2004-10-19 19:43
2004.12.05
Работа со сканером


3-1099648336
vvv
2004-11-05 12:52
2004.12.05
MasterSource-MasterField


1-1100932036
Leaner
2004-11-20 09:27
2004.12.05
Вход в CriticalSection


3-1099983334
SDA
2004-11-09 09:55
2004.12.05
Что такое методы асинхронного коннекта???