Завершено
4
12.10.2020, 14:06
02.11.2020, 06:48
Реализовать класс-аналог std::vector
, который был бы связан с файлом. Элементы вектора берутся из файла, запись элемента в вектор приводит к сохранению элемента в файл.
Такой класс может быть полезным для работы с огромным файлом, который целиком не помещается в память (допустим, 1 терабайт), но с которым хочется работать прозрачно, как со структурой данных, используя итераторы и т.д.
Однако постоянные чтение/запись элементов будут неэффективны. Чтобы справиться с этим, предлагается использовать «окно доступа». На старте выделяется память под окно (допустим, это будет 1 мегабайт). Обращение к первому элементу вектора вызовет загрузку окна (и, следовательно, второй, третий и т.д. элементы будут браться уже из памяти). Обращение к элементу, не попадающему в окно, вызовет перезагрузку окна. Перед этим, если содержимое окна модицифировалось, оно должно быть записано в файл.
operator[]
).resize
— изменение размера (в большую или меньшую сторону).flush
— явно сохранить текущие изменения в файл.push_back
— вставка в конец.pop_back
— получение элемента с конца с его последующим удалением.seek_window
– явно установить положение окна (перегрузить данный метод, чтобы можно было передавать и индекс, и итератор).Операции вставки и удаления в произвольном месте (не в конце) здесь не предлагаются — в силу своей неэффективности для файлов большого размера.
Работа с файлом должна производиться в двоичном режиме. Мы предполагаем, что тип элемента имеет фиксированный sizeof
и что можно использовать побайтовое чтение и запись.