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

Вниз

Ломанные линии. Запись на диск...   Найти похожие ветки 

 
Zilog ©   (2004-09-21 14:27) [0]

Нариосвал программку, позволяющую рисовать ломанные линии. (прокладывать маршруты). Алгоритм реализован следующим образом:

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

type TMapLine = class
 X,Y  : integer;
 Next   : pointer; //следующая точка (nil если такой нет)
 Prev   : pointer; //предыдущая точка точка (nil если такой нет)
end;

Говоря попросту - по сути все маршруты (сломанные линии) раскиданы в памяти где попало.

Задача - как все данные скинуть на диск (ну и грузить обратно, в последствии). Подскажите варианты Pls.


 
MBo ©   (2004-09-21 14:31) [1]

Обыкновенный обход связанного списка.
Задача сохранения будет проще и быстрее, если хранить данные последовательно - в динамическом массиве или псевдосписке типа TList - массив сохраняется одной командой.


 
Digitman ©   (2004-09-21 14:42) [2]


> раскиданы в памяти где попало


а чем изначально не угодили объекты, реализующие то же самое, но в виде массивов ? Тот же TList, например ? ЧЕМ опрадан выбор алгоритма хранения списка в виде несмежных (связанных ссылками) блоков ?


 
DiamondShark ©   (2004-09-21 14:58) [3]


> ЧЕМ опрадан выбор алгоритма хранения списка в виде несмежных
> (связанных ссылками) блоков ?

Например, удобно теоретико-множественные операции над объектами производить. Не надо массивы точек гонять с места на место. Только вставки/разрывы узлов.


 
Zilog ©   (2004-09-21 14:59) [4]

2Digitman MBo

А не могли бы вы пояснить, как использовать TList в моем случае?
а то я не очень понимаю...


 
Zilog ©   (2004-09-21 15:03) [5]

2 DiamondShark

я собственно так и делаю.
вопрос - как это записать на диск. и прочитать обратно.


 
MBo ©   (2004-09-21 15:05) [6]

>Zilog ©   (21.09.04 14:59) [4]
Не TList, а его аналог, вместо указателей содержащий записи твоего типа - причем Next,Prev уже не понадобятся, и можно просто TPoint хранить.


 
Digitman ©   (2004-09-21 15:05) [7]


> DiamondShark ©   (21.09.04 14:58) [3]


> Не надо массивы точек гонять с места на место. Только вставки/разрывы
> узлов


конечная производительность зависит от процентного соотношения числа операций вставок/удаления к числу операций выборок из списка

если список  редко обновляется, но гораздо чаще используется для поиска/выборки, то смежное хранение записей будет ощутимо эффективней


 
Zilog ©   (2004-09-21 15:07) [8]

А если поставить вопрос по другому:
мне удобна та форма представления, которая есть сейчас.
Как в таком случае решить проблему записи на диск?


 
Digitman ©   (2004-09-21 15:16) [9]

открываешь файл
двигаешься по списку, от первого эл-та до последнего
структуру TPoint очередного эл-та записываешь в открытый файл
закрываешь файл

какие сложности ?



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

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

Наверх




Память: 0.49 MB
Время: 0.036 c
4-1094239777
den.is
2004-09-03 23:29
2004.10.10
Ярлык к процессу , НО не к самой программе.


1-1095781449
SergeyRu
2004-09-21 19:44
2004.10.10
Подключение справки от компоненты к Делфи 6


14-1095754445
_User_
2004-09-21 12:14
2004.10.10
OpenSource проект на Delphi (WinAPI)


3-1095228605
Geoji
2004-09-15 10:10
2004.10.10
Поиск записи.


1-1095586738
appendix
2004-09-19 13:38
2004.10.10
выравнивание в текстовом файле