![]() |
Динамические списки в Delphi
Хм, возможно, я неправильно употребил словосочетание "динамические списики"? Вопрос(ы) в следующем:
1. Как работает тип TstringList в TListBox'e и подобные им списки/массивы переменной длины? 2. Файлы файлов объявлять низзя - это понятно, а можно ли создать такой вот "динамический список" из "динамических списков", или объектов, их включающих? Например, массив динамического размера, содержащим ListBox'ы(что можно работать с указателями - это понятно, но можно ли по-другому?)... 3. Может, кто-нить обьяснит, как сделать MDI - как в Word'e, например, или в Опере, чтобы не лимитировалось явно количество дочерних окон? Или, опять же, обязательно надо работать с массивом указателей и при создании нового окна делать New для нового элемента массива? А как же тогда обрабатывать событие нажатия на клавишу на N-ом окне? Как процедуры писать? :insane: |
1. Не совсем понимаю вопрос. Просто работает. Точно также, как и самый простой CList
2. Можно. Только не запутайтесь в указателях на указатели и грамотно очищайте память. 3. Емнип, никакого лимита в MDI приложениях по умолчанию нет. Что касается обработки сообщений, то тут всё просто. Внутри рабочей области окна все действия будут порождать события для этого конкретного окна. Если эти события не обрабатываются самим окном (дочерним), они передаются родителю (МDI-папе). Вкратце так. Поправьте, если ошибаюсь. |
hasherfrog, указатели на указатели?
А можно - поточнее? :) |
Новичёк
есть у нас, например, 10 указателей на соответственно 10 списков, почему бы не составить еще один список, элементами которого будут эти 10 указателей... |
Новичёк
Добавлю к сказанному Zippy Сам список организован на указателях. Все эти аппенды, инсёрты, реплэйсы, перемещение внутри списка - по сути работа с указателями на области памяти, в которых лежат данные элементов. |
1. Если есть возможность использовать STL, используйте list<...>. Там уже всё учтено (если, конечно то, что в угловых скобках грамотно написано, т.е. имеет конструкторы и деструктор). В делфи 5 и далее есть динамический массив, основанный на особенности выделения страничной памяти в Windows. Задаётся размер адресного пространства, занимаемый массивом и защищается NO_ACCESS. При попытке записать в защищённую память она автоматически выделяется.
2. Например list<list<list<double> > >. Непонятно, зачем это может понадобиться, тем не менее - это дин.спис. из дин.спис. из дин.спис. из вещественных. В STL в любом контейнерном классе есть возможность расти в объёме. Можно наример сделать так: Код:
void foo() { |
Время: 21:02. |
Время: 21:02.
© OSzone.net 2001-