Работа с дисками
Категория реферата: Рефераты по кибернетике
Теги реферата: ответы 8 класс, реферат история развития
Добавил(а) на сайт: Самуил.
Предыдущая страница реферата | 5 6 7 8 9 10 11 12 13 14 15 | Следующая страница реферата
. Используем номер первого кластера как индекс в таблице FAT для извлечения номера следующего кластера
. Повторяем предыдущую процедуру до тех пор, пока извлеченное из FAT значение не будет соответствовать концу файла
Процедура извлечения номера кластера из FAT зависит от формата таблицы размещения файлов.
16-битовую таблицу FAT можно представить как массив 16-битовых чисел. Для определения номера следующего кластера вам надо просто извлечь 16-битовое значение из FAT, использовав в качестве индекса номер предыдущего кластера.
Для 12-битовой таблицы FAT процедура значительно сложнее. Необходимо выполнить следующие действия:
. умножить номер начального кластера на 3;
. разделить результат на 2 (так как каждый элемент таблицы имеет длину
1,5 байта);
. прочитать 16-битовое слово из FAT , используя в качестве смещения значение, полученное после деления на 2;
. если номер начального кластера четный, на выбранное из FAT слово надо наложить маску 0FFFh, оставив младшие 12 бит, если же номер начального кластера нечетный, выбранное из FAT значение необходимо сдвинуть вправо на 4 бита, оставив старшие 12 бит;
. полученный результат - это номер следующего кластера в цепочке, при этом значение 0FFFh (или другое в диапазоне от 0FF8h до 0FFFh) соответствует концу цепочки кластеров.
Используя описанные выше процедуры просмотра FAT , вы сможете для каждого
файла определить цепочку занимаемых им кластеров. Для чтения файла при
помощи прерывания INT 25h вам будет нужно установить соответствие между
номерами кластеров и номерами секторов, в которых располагаются эти
кластеры. Для того чтобы это сделать, необходимо определить расположение и
размер корневого каталога. Поэтому следующий раздел книги будет посвящен
каталогам и файлам. Там же будут приведены примеры программ для работы с
FAT.
21. Файлы и каталоги.
Вы, конечно, знаете, что файловая система MS-DOS имеет древовидную структуру. В корневом каталоге располагаются 32-байтовые элементы, которые содержат информацию о файлах и других каталогах. Для чтения корневого каталога необходимо определить его расположение и размер.
6.22 Расположение и размер корневого каталога.
Корневой каталог находится сразу за последней копией FAT . Количество
секторов, занимаемых одной копией FAT, находится в блоке параметров BIOS в
загрузочном секторе (поле fatsize), а количество копий FAT - в поле fatcnt
блока BPB . Следовательно, перед корневым каталогом находится один
загрузочный сектор и fatcnt * fatsize секторов таблицы размещения файлов
FAT.
Размер корневого каталога можно определить исходя из значения поля rootsize. При форматировании диска в это поле записывается максимальное количество файлов и каталогов, которые могут находиться в корневом каталоге. Для каждого элемента в каталоге отводится 32 байта, поэтому корневой каталог имеет длину 32 * rootsize байт.
Корневой каталог занимает непрерывную область фиксированного размера.
Размер корневого каталога задается при форматировании и определяет
максимальное количество файлов и каталогов, которые могут быть в нем
описаны.
Для определения количества секторов, занимаемых корневым каталогом, можно воспользоваться следующей формулой:
RootSecs = sectsize / (32 * rootsize)
В этой формуле sectsize - размер сектора в байтах, он может быть получен из
соответствующего поля загрузочного сектора.
22. Область файлов и подкаталогов.
Вслед за корневым каталогом на логическом диске находится область файлов и подкаталогов корневого каталога.
Область данных разбита на кластеры, причем нумерация кластеров начинается с числа 2. Кластеру с номером 2 соответствуют первые секторы области данных.
Теперь мы можем привести формулу, которая позволит нам связать номер кластера с номерами секторов, занимаемых им на логическом диске:
SectNu = DataStart + ((ClustNu - 2) * clustsize)
В этой формуле использованы следующие обозначения:
|SectNu |номер первого сектора, распределенного кластеру с номером |
| |ClustNu; |
|DataSta|начало области данных, вычисляется по формуле: ressecs + |
|rt |(fatsize * fatcnt) + (32 * rootsize/ sectsize); |
|ClustNu|номер кластера, для которого необходимо определить номер первого|
| |сектора; |
|clustsi|количество секторов, занимаемых кластером; находится в блоке |
|ze |параметров BIOS. |
Рекомендуем скачать другие рефераты по теме: список литературы реферат, изложение дубровский.
Предыдущая страница реферата | 5 6 7 8 9 10 11 12 13 14 15 | Следующая страница реферата