Системное Программное Обеспечение Курсовая Работа
Системное Программное Обеспечение Курсовая Работа
Информационное обеспечение, программирование
Вы можете узнать стоимость помощи в написании студенческой работы.
Помощь в написании работы, которую точно примут!
Похожие работы на - Системное программное обеспечение
Скачать Скачать документ
Информация о работе Информация о работе
Скачать Скачать документ
Информация о работе Информация о работе
Скачать Скачать документ
Информация о работе Информация о работе
Скачать Скачать документ
Информация о работе Информация о работе
МИНИСТЕРСТВО ОБРАЗОВАНИЯ И НАУКИ
РОССИЙСКОЙ ФЕДЕРАЦИИ
Федеральное государственное
автономное образовательное учреждение высшего профессионального образования
«САНКТ-ПЕТЕРБУРГСКИЙ ГОСУДАРСТВЕННЫЙ
УНИВЕРСИТЕТ АЭРОКОСМИЧЕСКОГО ПРИБОРОСТРОЕНИЯ»
КАФЕДРА управления в технических
системах
по дисциплине: Системное программное
обеспечение
Информация на компьютерах, хранятся на постоянном запоминающем устройстве
(ПЗУ) в виде именованных последовательностей, называемых файлами. Хранение
файлов подобно хранению книг в библиотеке, и для организации доступа к ним
требуется специальная система, обеспечивающая минимизацию времени доступа и
удобство работы.
Файловая система представляет совокупность служебных структур на носителе
и средств операционной системы, обеспечивающих манипуляцию файлами.
Файловая система FAT (File Allocation Table) была разработана Биллом
Гейтсом и Марком МакДональдом в 1977 году и первоначально использовалась в
операционной системе 86-DOS. Чтобы добиться переносимости программ из
операционной системы CP/M в 86-DOS, в ней были сохранены ранее принятые
ограничения на имена файлов. В дальнейшем 86-DOS была приобретена Microsoft и
стала основой для ОС MS-DOS 1.0, выпущенной в августе 1981 года.
Система FAT 16, являющаяся основной для операционных систем DOS, Windows
95⁄98⁄Me, Windows NT⁄2000⁄XP, а также поддерживается
большинством других систем. FAT 16 представляет собой простую файловую систему,
разработанную для небольших дисков и простых структур каталогов.
Название происходит от названия метода организации файлов - Таблица
размещения файлов (File Allocation Table). Эта таблица размещается в начале
диска. Число 16 означает, что данная файловая система 16-разрядная - для
адресации кластеров используется 16 разрядов. Операционная система использует
Таблицу размещения файлов для поиска файла и определения кластеров, которые
этот файл занимает на жестком диске. Кроме того, в Таблице фиксируются сведения
о свободных и дефектных кластерах. Чтобы легче было осмыслить файловую систему
FAT16 представьте себе оглавление книги и как вы работаете с этим оглавлением,
вот именно также операционная система работает с FAT 16.
Каждому кластеру в FAT соответствует отдельная запись, которая
показывает, свободен ли он, занят ли данными файла, или помечен как сбойный
(испорченный). Если кластер занят под файл, то в соответствующей записи в
таблице размещения файлов указывается адрес кластера, содержащего следующую
часть файла. Из-за этого FAT называют файловой системой со связанными списками.
Оригинальная версия FAT, разработанная для DOS 1.00, использовала
12-битную таблицу размещения файлов и поддерживала разделы объемом до 16 Мб (в
DOS можно создать не более двух разделов FAT). Для поддержки жестких дисков
размером более 32 Мб разрядность FAT была увеличена до 16 бит, а размер
кластера - до 64 секторов (32 Кб). Так как каждому кластеру может быть присвоен
уникальный 16-разрядный номер, то FAT поддерживает максимально 216, или 65536
кластеров на одном томе.
Разработать программу, реализующую функции файлового обмена (чтение,
запись) с образом файловой системы FAT16.
жесткий диск форматирование файловый
Способность дисков хранить данные основывается на использовании
намагниченных участков, движение, мимо которых, считывающего устройства
возбуждает в этом устройстве импульсы тока. Намагниченные и не намагниченные
участки соответствуют единичному и нулевому битам информации, хранящейся на
диске. Но не они являются единицами распределения дискового пространства.
Жесткие диски состоят из одной или более дисковых пластин, у которых для
хранения используется одна или обе стороны. Данные записываются на магнитной
поверхности стороны диска в виде концентрических окружностей, называемых
дорожками (рис.1). Каждая дорожка состоит из нескольких секторов (рис.2).
Размер сектора и их количество на дорожке задается при форматировании. Именно
сектор является единицей разбиения дискового пространства.
Для доступа к сектору необходимо указать его местоположение на диске,
т.е. его адрес. Это может делаться двумя способами.
Первый из способов заключается в указании номера дорожки (иногда
называемого номером цилиндра), номера стороны (головки), и номера сектора.
Второй способ состоит в сквозной последовательной нумерации секторов от края
диска к центру. Эта нумерация начинается с самой внешней дорожки 0, стороны 0,
сектора 1 (нумерация дорожек и сторон начинается с 0, а секторов с 1), затем
продолжается вдоль дорожки по нарастанию номеров секторов.
После прохождения на дорожке сектора с наибольшим номером, следующим
становится сектор с номером дорожки 0, номером стороны 1 и номером сектора 1,
т.е. счет секторов продолжается по возрастанию сторон. Переход на следующую
дорожку осуществляется не раньше, чем пронумерованы все сектора на всех
сторонах текущей дорожки.
Логическая структура жёстких дисков
Логическая структура жёсткого диска предполагает деление общего дискового
пространства на области, каждая из которых хранит специфическую информацию: MBR
(Master Boot Record), BR (Boot Record), FAT1 и FAT2, Root Directory и область
для данных.это главный загрузочный сектор, это первый сектор на диске, с чтения
его содержимого начинается работа компьютера при включении или перезагрузке.
MBR состоит из двух частей: в первой части записана программа IPL1- Initial
Program Loading 1, при выполнении которой компьютер исследует содержимое второй
части MBR- таблицу разделов диска Partition Table, в которой указаны номера
первого и последнего секторов каждого из разделов диска.
Количество разделов может быть от 1 до 4-х, когда диск условно разделён
на 4 логических диска. В Partition Table также хранится информация о типе
файловой системы раздела и признак того- является раздел загрузочным или нет.
Каждый из разделов жёсткого диска содержит сектор BR (Boot Record), две копии
File Allocation Table (FAT )- FAT1 и FAT2, корневой каталог Root Directory и
область данных.
Сектор BR (Boot Record)- это первый сектор раздела, в котором записана
одноимённая программа Boot Record, являющаяся частью операционной системы и
предназначенная для запуска на выполнение остальных программ операционной
системы, хранящихся на диске. BR имеется во всех разделах жёсткого диска, хотя
не все разделы содержат файлы операционной системы, т.е. не все разделы
являются "системными".
Таблица FAT (File Allocation Table) - таблица размещения файлов, хранит
записи длиной 16 или 32 бита, хранящие информацию о месторасположении
кластеров, на которых записан каждый файл. Если FAT повреждается, то компьютер
теряет доступ к файлу и на диске появляются "потерянные кластеры"-
т.е. секторы с бесполезной информацией, которую невозможно прочесть.Directory-
корневой каталог диска, содержит записи с информацией о каждом файле - имя,
тип, объём, дата и время создания, атрибут файла (системный, скрытый, только
для чтения, архивный) и хранит указатель на первый кластер файла. Корневой
каталог является самым «главным» каталогом в разделе диска, все остальные
каталоги и файлы располагаются по иерархии ниже его.Area- область для данных-
основная область раздела диска, хранит сами файлы.
Физическая и логическая структуры жёсткого диска создаются в процессе
форматирования. В отличие от дискет, процесс форматирования жёсткого диска
разбит на 2 этапа- низкоуровневое форматирование и форматирование высокого
уровня. Низкоуровневое форматирование выполняется один раз на
заводе-изготовителе. Форматирование высокого уровня выполняется утилитой
Format.exe, хранящейся на загрузочной дискете, либо соответствующими средствами
Windows.
//---------------------------------------------------------------------------
//---------------------------------------------------------------------------
//int,short - целочисленные, char - символьные,f;data , sdv;{ //Структура
загрузочных переменныхjmp[3];oem[8];sect_siz;clust_siz;res_sect;fat_cnt;root_siz;tot_sect;media;fat_siz;sectors;heads;hidden_1;hidden_h;tot_secs;fiz_disk;reserved_1;symbol;s_nom;v_lable[11];reserved_2[8];
}boot ; //Окончание структуры, название: bootshort rez [32768] ; //Размер
16 bit, целочисленная{ //Структура переменных для файловname[8]; //Имя
файлаrs[3];atribut;reserv[10];time; //Время созданияdate; //Дата созданияnkl;
//Номер первого кластера файлаsize; //Размер файла
}dir[1024]; //Окончание структуры, название dir,вместимость 1024{
//Структура для файловname[8]; //Имя файлаrs[3];atribut;reserv[10];time;
//Время созданияdate; //Дата созданияnkl; //Номер первого кластера файлаsize;
//Размер файлаclust; //Кол. кластеровfile; //Сам фаил
}files[1024];root_pos;fat_pos ;kat_siz ; //Размер каталогаdata_start ;
//Начало области файловtot_siz ; //Размер диска в байтахdata_siz ; //Байтов под
файлыfat_tot_siz ; //Байтов под фатыclust_b_siz ; //Байтов в кластереclust_data
; //Кластеров под файлыmain(int argc, char* argv[]) //Условная переменная
{ int i,k,n,j;(argc !=2){//Сравнение двух аргументов, при
совпадении("usage: program image \n"); //Использовать програмное
изображение();//Ожидаем нажатие клавиши, и(0);} //Выход (для того, чтоб не было
ошибок)= open(argv[1], O_RDONLY|O_BINARY); //только для чтения
//в бинарном коде(f<0){ //если не удалось открыть
getch();//Ошибка и ожидает нажатия для выхода
exit(0);}("Hello Neo... \n"); //Приветствие =)
getch();(); //Отчистка приветствия("boot parametrs:
\n");//Заголовок параметры("\n"); //Пропуск строки(f,&boot,
sizeof(boot));//Считать f в boot
//Размер считывания размер boot в двоичном коде("oem: %.8s\n",
boot.oem);//Автор("sect_siz: %d\n", boot.sect_siz); //Байтов в
секторе диска("clust_siz: %d\n", boot.clust_siz); //Сектаров в кластере("res_sect:
%d\n", boot.res_sect);//Зарезервированных секторов
printf("fat_cnt: %d\n", boot.fat_cnt); //Таблиц фат
printf("root_siz: %d\n", boot.root_siz);//Максимум файлов в
каталоге("tot_sect: %d\n", boot.tot_sect);//Всего
секторов("media: %d\n", boot.media); //Среда носителя("fat_size:
%d\n", boot.fat_siz);//Секторов на одну копию Fat
printf("sectors: %d\n", boot.sectors); //Секторов на дорожке
printf("heads: %d\n", boot.heads);
//Сторон(головок)("hidden_1: %d\n", boot.hidden_1);//Скрытых секторов
раздела, меньше 32 мБайт("hidden_h: %d\n", boot.hidden_h);//Скрытых
секторов раздела, больше 32 мБайт("tot_secs: %d\n",
boot.tot_secs);//Секторов для раздела на логическом д. больше 32
мБайт("fiz_disk: %d\n", boot.fiz_disk);//Физический номер
диска("reserved_1: %d\n",
boot.reserved_1);//Зарезервированно("symbol: %d\n",
boot.symbol);//Тип загрузочной записи("s_nom: %d\n",
boot.s_nom);//Серийный номер диска("v_lable: %d\n",
boot.v_lable);//Метка диска("reserved_2: %d\n",
boot.reserved_2);//Зарезервировано, обозначение
формата();("\n");//Пропуск строки("Match: \n");
//Заголовок();("\n");//Пропуск строки_siz = (boot.tot_sect *
boot.sect_siz);//Размер диска в байтах("Tot_siz: %d\n", tot_siz);
root_pos = (boot.fat_siz * boot.fat_cnt + boot.res_sect)*
boot.sect_siz;
printf("root_pos: %d\n", root_pos); //Байтов на фаты и резерв
fat_pos = ( boot.res_sect * boot.sect_siz);
printf("fat_pos: %d\n", fat_pos); //Байтов на резерв
fat_tot_siz = (root_pos - fat_pos) ;
printf("Fat_tot_siz: %d\n", fat_tot_siz); //Байтов на таблицы
фат
printf("Kat_siz: %d\n", kat_siz); //Размер каталога
data_start = (root_pos + kat_siz);//Область начала файлов
printf("Data_start: %d\n", data_start);
data_siz = (tot_siz - data_start);//Байтов под файлы
printf("Data_siz: %d\n", data_siz);
data_siz = (tot_siz - data_start);//Байтов под файлы
printf("Data_siz: %d\n", data_siz);_b_siz = (boot.clust_siz *
boot.sect_siz);//Байтов в кластере("Clust_b_siz: %d\n",
clust_b_siz);_b_siz = (boot.clust_siz * boot.sect_siz);//Байтов в
кластере("Clust_b_siz: %d\n", clust_b_siz);
clust_data = (data_siz /clust_b_siz);//Кластеров под файлы
getch();("\n");//Пропуск строки("Read katalog... \n");();("\n");//Пропуск
строки(f, fat_pos, SEEK_SET); //Смещение от начала на
// fat_pos(количество резервных), от начала(f, rez, fat_tot_siz);
//Считываем f в rez размером boot.fat_size * boot.sect_size
// т.е. размер одного FAT, значит записываем FAT(талицу) в rez(f,
root_pos, SEEK_SET); //Смещение от начала на
//root_pos (размер фатов + резерв)(f, dir, kat_siz);//Считываем f в dir
//с отступом в root_pos, считываем корневой каталог (размером 32
байта)(f, data_start, SEEK_SET); //Смещение от начала на
// data_start(начало файлов), от начала(f, data, data_siz);//Считываем в
Data файловую область= 0;(i=0; i>5,
1980+((dir[i].date&0xf800)>>9));
//Выводим дату("time: %02d:%02d:%02d",
(dir[i].time&0xf800)>>11, (dir[i].time&0x7e)>>5,
dir[i].time&0x01f);
//Выводим время(" \n\n");//Пропуск строки
//Далее выполняем чтение в структуру Files найденных файлов
files[j].time = dir[i].time;[j].date = dir[i].date;[j].nkl =
dir[i].nkl;[j].size = dir[i].size;[j].atribut = dir[i].atribut;
//---------------------------------------------------------------------------
В файловой системе FAT16 под номер кластера отведено 16 разрядов. Поэтому
максимальное количество кластеров составляет 65525, а максимальный размер
кластера 128 секторов. В таком случае максимальный размер разделов или дисков в
FAT16 составляет 4,2 гигабайта. При логическом форматировании диска или раздела
операционная система старается использовать минимальный размер кластера, при
котором получающееся количество кластеров не превышает 65525. Очевидно, что чем
больше размер раздела, тем больше должен быть размер кластера. Многие
операционные системы неправильно работают с кластером размером в 128 секторов.
В результате максимальный размер раздела FAT16 уменьшается до 2 гигабайт.
Обычно чем больше размер кластера, тем больше становятся потери дискового
пространства. Это связано с тем, что последний кластер, занимаемый файлом,
заполнен лишь частично. Например, если файл размером 17 Кбайт записывается в
раздел с размером кластера 16 Кбайт, то этот файл займет два кластера, причем
первый кластер будет заполнен полностью, а во втором кластере будет записан
только 1 Кбайт данных, а остальные 15 Кбайт пространства второго кластера
останутся не заполненными и будут недоступными для записи других файлов. Если
на больших дисках записывается большое количество маленьких файлов, то потери
дискового пространства будут значительны.
Чтобы прочитать файл, операционная система должна найти по имени файла
запись в папке и прочитать номер первого кластера файла. Первый кластер представляет
собой начало файла. Затем необходимо прочитать соответствующий первому кластеру
файла элемент FAT. Если элемент содержит метку- последний в цепочке, то дальше
ни чего искать не нужно: весь файл умещается в одном кластере. Если кластер не
последний, то элемент таблицы содержит номер следующего кластера. Содержимое
следующего кластера должно быть прочитано вслед за первым. Когда будет найден
последний кластер в цепочке, то, если файл не занимает весь кластер целиком,
необходимо отсечь лишние байты кластера. Лишние байты отсекаются по длине
файла, хранящейся в записи папки.
Чтобы записать файл, операционная система должна выполнить следующую
последовательность действий. В свободном элементе папки создается описание
файла, затем ищется свободный элемент FAT, и ссылка на него размещается в
записи папки. Занимается первый кластер, описываемый найденным элементом FAT. В
этот элемент FAT помещается номер следующего кластера или признак последнего
кластера в цепочке.
Операционная система действует таким таким образом, чтобы собирать
цепочки из соседних кластеров по нарастанию номера. Понятно, что обращение к
последовательно расположенным кластерам будет происходить значительно быстрее,
чем к кластерам, случайным образом разбросанным по диску. При этом игнорируются
уже занятые и помеченные в FAT как дефектные кластеры.
1. Барри
Саймон. Файловая система FAT32 для Windows 95. PC Magazine, Апрель 8, 1997,
стр.279.
. Хелен
Кастер. Основы Windows NT и NTFS/Пер. с англ. - М: Издательский отдел “Русская
редакция” ТОО “Channel Trading Ltd.”, 1996.-440 с.
. Ресурсы
Windows NT: пер. с англ. - СПб.: BHV - Санкт-Петербург, 1996. - 720 с.
. Фролов
А.В., Фролов Г.В. Программирование для Windows NT. - М.: ДИАЛОГ-МИФИ, 1996. -
272 с. Т. 26.
. Фролов А.В.,
Фролов Г.В. Программирование для Windows NT. - М.: ДИАЛОГ-МИФИ, 1997. - 271 с.
Т. 27.
. Нортон П.
Персональный компьютер фирмы IBM и операционная система MS-DOS: Пер. с англ. -
М.: Радио и связь, 1991. С. 416.
Системное программное обеспечение . Курсовая работа ...
Системное программное обеспечение
курсовая работа - Системное программное ...
Системное программное обеспечение
Системное программное обеспечение | реферат
Эссе По Обществознанию На Тему Семейный Бюджет
Сочинение Дубровский Вступление
Реферат На Тему Внебюджетные Фонды Рф
Эссе Предпринимательство Это Американизм
Фундаментальные Науки Реферат