Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Программирование и базы данных (http://forum.oszone.net/forumdisplay.php?f=21)
-   -   Динамические списки в Delphi (http://forum.oszone.net/showthread.php?t=41558)

Новичёк 24-11-2004 23:56 275145

Динамические списки в Delphi
 
Хм, возможно, я неправильно употребил словосочетание "динамические списики"? Вопрос(ы) в следующем:
1. Как работает тип TstringList в TListBox'e и подобные им списки/массивы переменной длины?
2. Файлы файлов объявлять низзя - это понятно, а можно ли создать такой вот "динамический список" из "динамических списков", или объектов, их включающих? Например, массив динамического размера, содержащим ListBox'ы(что можно работать с указателями - это понятно, но можно ли по-другому?)...
3. Может, кто-нить обьяснит, как сделать MDI - как в Word'e, например, или в Опере, чтобы не лимитировалось явно количество дочерних окон? Или, опять же, обязательно надо работать с массивом указателей и при создании нового окна делать New для нового элемента массива? А как же тогда обрабатывать событие нажатия на клавишу на N-ом окне? Как процедуры писать? :insane:

hasherfrog 25-11-2004 11:52 275243

1. Не совсем понимаю вопрос. Просто работает. Точно также, как и самый простой CList
2. Можно. Только не запутайтесь в указателях на указатели и грамотно очищайте память.
3. Емнип, никакого лимита в MDI приложениях по умолчанию нет. Что касается обработки сообщений, то тут всё просто. Внутри рабочей области окна все действия будут порождать события для этого конкретного окна. Если эти события не обрабатываются самим окном (дочерним), они передаются родителю (МDI-папе). Вкратце так.
Поправьте, если ошибаюсь.

Новичёк 27-11-2004 11:55 275859

hasherfrog, указатели на указатели?
А можно - поточнее? :)

Zippy 03-12-2004 01:20 277451

Новичёк
есть у нас, например, 10 указателей на соответственно 10 списков, почему бы не составить еще один список, элементами которого будут эти 10 указателей...

hasherfrog 03-12-2004 09:05 277500

Новичёк
Добавлю к сказанному Zippy
Сам список организован на указателях. Все эти аппенды, инсёрты, реплэйсы, перемещение внутри списка - по сути работа с указателями на области памяти, в которых лежат данные элементов.

pva 14-12-2004 10:57 280037

1. Если есть возможность использовать STL, используйте list<...>. Там уже всё учтено (если, конечно то, что в угловых скобках грамотно написано, т.е. имеет конструкторы и деструктор). В делфи 5 и далее есть динамический массив, основанный на особенности выделения страничной памяти в Windows. Задаётся размер адресного пространства, занимаемый массивом и защищается NO_ACCESS. При попытке записать в защищённую память она автоматически выделяется.

2. Например list<list<list<double> > >. Непонятно, зачем это может понадобиться, тем не менее - это дин.спис. из дин.спис. из дин.спис. из вещественных.
В STL в любом контейнерном классе есть возможность расти в объёме. Можно наример сделать так:
Код:

void foo() {
  vector<auto_ptr<TListBox> > listboxes;
  listboxes.resize(10);
  for(int i=0; i<listboxes.size(); i++) listboxes[i].reset(new TListBox);

  listboxes.resize(20);
  for(int i=10; i<listboxes.size(); i++) listboxes[i].reset(new TListBox);
}

...
foo();
// здесь все listbox-ы самоуничтожатся
// указателей на указатели не используется
// выгодно для доступа, но тормозит при добавлении и удалении в середине списка



Время: 21:02.

Время: 21:02.
© OSzone.net 2001-