- •Содержание
- •1 Списковые структуры и динамическая память 10
- •2 Списковые структуры и файлы 79
- •3 Мультисписковые структуры 121
- •4 Указатели на функции 134
- •5 Совместное использование указателей на данные и указателей на функции 141
- •6 Оформление курсового проекта 157
- •Введение
- •1Списковые структуры и динамическая память
- •1.1Представления однонаправленных списков массивами указателей на элементы списка
- •1.1.1Представление однонаправленных списков массивами указателей
- •1.1.2Статические массивы указателей
- •1.1.3Операции со списками в статических массивах указателей
- •1.1.4Статические массивы указателей в динамической памяти
- •1.1.5Операции со списками в статических массивах указателей в динамической памяти
- •1.1.6Динамические массивы указателей
- •1.1.7Динамические массивы типизированных указателей
- •1.1.8Операции со списками в динамических массивах типизированных указателей
- •1.1.9Динамические массивы нетипизированных указателей
- •1.1.10Операции со списками в динамических массивах нетипизированных указателей
- •1.1.11Продолжение. Динамические массивы нетипизированных указателей
- •1.1.12Замечания по оператору &
- •1.1.13Нетипизированые указатели и массивы
- •1.1.14Нетипизированые указатели и память
- •1.1.15Продолжение. Динамические массивы нетипизированных указателей
- •2Списковые структуры и файлы
- •2.1Бестиповые файлы и однонаправленные списки на базе массивов указателей на элементы списка
- •2.1.1Представление однонаправленных списков массивами указателей
- •2.1.2Организация файла с однонаправленным списком на базе массивов указателей на элементы списка
- •2.1.3Статические и динамические массивы указателей
- •2.1.4Организация списка дыр
- •2.1.5Функция инициализации файла со списком
- •2.1.6Функция открытия файла со списком
- •2.1.7Функции корректировки указателя на начало списка, заголовка списка дыр, количества элементов списка и текщего размера массива указателей
- •2.1.8Функция выделения записи для нового элемента списка
- •2.1.9Функция освобождения записи удаляемого элемента списка
- •2.1.10 Функция увеличения размера массива указателей на элементы списка
- •2.1.11 Функция вывода содержимого списка
- •2.1.12 Функция поиска элемента списка
- •2.1.13Функция добавления элемента в неотсортированный список
- •2.1.14Функция добавления элемента в отсортированный список
- •2.1.15Функция удаления элемента из отсортированного списка
- •2.1.16Функция удаления списка
- •2.1.17 Функция удаления списка с усечением файла
- •2.1.18 Пример программы обработки отсортированного списка на базе массивов указателей
- •2.1.19Продолжение. Представление однонаправленных списков массивами указателей
- •2.1.20Функция инициализации файла со списком
- •2.1.21Процедура открытия файла со списком
- •2.1.22Процедура корректировки заголовка списка
- •2.1.23 Процедура увеличения размера массива указателей на элементы списка
- •2.1.24Функция поиска элемента списка или позиции вставки нового элемента методом половинного деления
- •2.1.25Функция вывода списка на экран
- •2.1.26Функция добавления нового элемента в отсортированный список
- •2.1.27Функция удаления элемента из отсортированного списка
- •2.1.28Функция удаления списка с усечением файла
- •3Мультисписковые структуры
- •3.1Назначение мультисписков
- •3.2Мультисписки в динамической памяти
- •3.3Мультисписки в бинарных файлах
- •3.4Сохранение и восстановление мультисписка в динамической памяти
- •4Указатели на функции
- •4.1Понятие указателя на функцию и его объявление
- •4.2Переменная-указатель на функцию как параметр другой функции
- •4.3Условия использования указателей на функции
- •4.4Использование указателей на функцию для вызова функций
- •4.4.1Формат переменных-указателей на функцию и бестиповых указателей
- •4.4.2Преобразование переменной-указателя на функцию к бестиповому указателю на функцию
- •4.4.3Вызов функции через бестиповый указатель на функцию
- •4.4.4Преобразование бестипового указателя к переменной типа указатель на функцию
- •4.5Способы вызова функции через указатель на функцию
- •4.5.1Массивы указателей на функции
- •5Совместное использование указателей на данные и указателей на функции
- •5.1Инвариантные функци
- •5.2Функции сравнения
- •5.3Пример 1
- •5.4Пример 2
- •6Оформление курсового проекта
- •6.1Интерфейс программной системы
- •6.2Взаимодействие с мультисписком
- •6.3Отображение содержимого мультисписка
- •6.4Файл справки
- •6.5Документация по курсовому проекту
- •6.5.1Общие положения
- •6.5.2Курсовой проект/работа
- •6.5.3Пояснительная записка
- •6.5.4Техническое задание
- •6.5.5Реферат
- •6.5.6Содержание
- •6.5.7Введение
- •6.5.8 Постановка задачи
- •6.5.9 Анализ решаемой задачи
- •6.5.10Анализ существующих методов организации динамических структур данных
- •6.5.11 Определение путей и методов решения задачи
- •6.5.12Проектирование программы
- •6.5.13Заключение
- •6.5.14Список использованных источников
- •6.6Приложения
2.1.4Организация списка дыр
Ранее при построении списков с узловым представлением для организации списка дыр, образующихся при очередном удалении элемента списка, использовалось поле NextRec этого элемента.
Однако при построении списков на базе массивов указателей элементы списка не имеют такого поля. Вместе с тем список дыр, по прежнему, целесообразно строить как список с узловым представлением, что удобно при занесении и выборке очередной дыры из головы списка.
Кроме того, в файле, содержащем список на основе динамических массивов указателей, образуются дыры двух типов – дыры от удаления элементов списка, и дыры от удаления устаревших массивов указателей на элементы списка.
В связи с этим будем различать простую и модифицированную организацию списка дыр.
Простая организация списка дыр предусматривает построение списка дыр, образующихся только от удаления элементов списка. Дырами, образующимися от удаления устаревшего массива указателей на элементы списка, при этом пренебрегают.
При простой организации списка дыр для связывания дыр в единый список имеет смысл первые 4‑ре байта в каждой из дыр использовать для ссылки на следующий элемент списка дыр NextHole. Последний элемент списка дыр в этом поле будет содержать значение –2. Следует подчеркнуть, что элемент списка при таком решении не может быть меньше 4‑х байт.
№ байта |
0 3 |
4 N |
|
NextHole |
остаток дыры |
Рисунок 2.4 – Структура дыры, содержащей адрес следующей дыры
Модифицированная организация списка дыр предусматривает построение списка дыр, образующихся как от удаления элементов списка, так и от удаления устаревших массивов указателей на элементы списка. В общем случае размер этих дыр не совпадает. Поэтому в каждой дыре помимо указателя на следующую дыру необходимо содержать размер конкретной дыры. Для этого имеет смысл вторые 4‑ре байта в каждой из дыр – поле размера дыры - SizeHole, использовать для хранения размера дыры или размера свободной части дыры. Следует подчеркнуть, что элемент списка при таком решении не может быть меньше 8‑ми байт.
№ байта |
0 3 |
4 7 |
8 N |
|
NextHole |
SizeHole |
остаток дыры |
Рисунок 2.5 – Структура дыры, содержащей размер и адрес следующей дыры
Модифицированная организация списка дыр предоставляет возможность объединять смежные дыры в одну дыру большего размера. Это решение приводит к модификации процедуры выбора дыры для нового элемента списка или для нового массивов указателей на элементы списка.
Непустой список дыр просматривается, пока не будет найдена первая по порядку дыра, размер которой больше или равен запрашиваемому размеру, или не исчерпается весь список дыр.
Если размер найденной дыры равен запрашиваемому размеру, то дыра изымается из списка дыр и предается в распоряжение списка элементов.
Если размер найденной дыры больше запрашиваемого размера, то требуемый объем изымается из дыры и предается в распоряжение списка элементов, после чего выполняется корректировка поля размера дыры.
Если список дыр пуст или не содержит дыры требуемого размера, то память, необходимая для соответствующей составляющей списка элементов, выделяется в конце файла.
В приводимой ниже реализации списка на базе массива указателей на элементы списка используется простая организация списка дыр. Однако реализация модифицированной организации списка дыр не представляет особой сложности.
Примечание. Следует подчеркнуть, что в приводимой ниже реализации функций они в качестве параметров получают всю необходимую информацию о характеристиках списка: позиция в файле начала массива указателей, размер массива указателей и реальное количество элементов списка. В действительности эту информацию можно получить внутри каждой функции, используя соответствующие фрагменты текста функции открытия файла. Это сделает подпрограммы более автономными, но приведет к замедлению их работы.
