Войти

Показать полную графическую версию : Динамические списки в Delphi


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

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

Новичёк
27-11-2004, 11:55
hasherfrog, указатели на указатели?
А можно - поточнее? :)

Zippy
03-12-2004, 01:20
Новичёк
есть у нас, например, 10 указателей на соответственно 10 списков, почему бы не составить еще один список, элементами которого будут эти 10 указателей...

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

pva
14-12-2004, 10:57
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-ы самоуничтожатся
// указателей на указатели не используется
// выгодно для доступа, но тормозит при добавлении и удалении в середине списка




© OSzone.net 2001-2012