Главная | Обратная связь | Поможем написать вашу работу!
МегаЛекции

Глава II. Технологический раздел

Содержание

Введение

Глава I. Теоретический раздел

1.1 Понятие жёсткого диска.

1.2 Контролёр HDD

Глава II. Технологический раздел

2.1 Заголовочные файлы

2.2 Собственные подпрограммы

Заключение

Список литературы

Приложение


Введение

 

Программирование - процесс и искусство создания компьютерных программ с помощью языков программирования. Программирование сочетает в себе элементы искусства, науки, математики и инженерии.

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

Большая часть работы программиста связана с написанием исходного кода на одном из языков программирования.

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

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

В данной курсовой работе для разработки программы использовался язык С и среда программирования Borland C++ 3.1

Задача курсовой работы состоит в разработке на языке программирования С++ программы анализа логических дисков, которая должна осуществлять следующие функции:

) Графический интерфейс, диалог с пользователем.

) Определение текущего диска.

) Вывод всей информации о кластерах на диске.

) Определение общего размера диска.

) Определение занятого и свободного места на диске.

) Изобразить диаграмму.

Работа программы должна быть организована с использованием меню.


Глава I. Теоретический раздел

 

Понятие жёсткого диска.

 

Жёсткий магнитный диск - это специальное устройство, предназначенное для хранения значительных объёмов информации. В отечественной литературе можно встретить различные термины и аббревиатуры для этого устройства: накопитель на магнитном диске (НМД), жёсткий диск, винчестер. Будем пользоваться аббревиатурой HDD, которая является общепринятой для зарубежной литературы. Эта аббревиатура произошла от названия Hard Disk Drive, что означает "дисковод для жесткого диска”.

В первых компьютерах дисковая память состояла из двух устройств - дисковода и пакета магнитных дисков. Причём пакеты магнитных дисков были сменными. Это давало возможность устанавливать на один и тот же дисковод разные пакеты дисков.

Для персональных компьютеров обычно используется другая конструкция дисковой памяти. Пакет магнитных дисков и дисковод объединены в общем, герметично закрытом корпусе, на общей оси вращаются несколько дисков, покрытых с двух сторон слоем ферромагнитного материала. Назначение этого покрытия аналогично назначению магнитного покрытия ленты в обычном бытовом магнитофоне. Сверху и снизу к дискам почти вплотную подводятся магнитные головки, также напоминающие по принципу магнитные головки магнитофона. Такая конструкция получила название "винчестер”. Головки "парят" на воздушной подушке очень близко к поверхности дисков, как бы прочерчивая окружности. С помощью специального шагового двигателя блок головок может перемещаться в направлении к центру дисков. Так как блок головок перемещается скачкообразно, головки при их перемещении прочерчивают концентрические окружности, называемые дорожками. Совокупность всех дорожек, образуемых всеми магнитными головками, называют цилиндром. Информация в жестких дисках записывается на дорожках. Каждая дорожка однозначно определяется своим порядковым номером на диске относительно внешнего края и номером головки (так как каждая головка соответствует определённой поверхности одного из дисков, вращающихся на общей оси). Эта информация записывается не сплошным потоком (как в бытовых магнитофонах), а блоками одинаковой длины. Каждый блок содержит некоторую служебную информацию и 512 байтов данных. Блоки обычно называются секторами дорожки. Эти секторы идентифицируются своим порядковым номером относительно начала дорожки. Начало дорожки отмечается специальной меткой - маркером дорожки.

Контролёр HDD

 

Контроллер HDD-это специальное устройство, предназначенное для подключения HDD к компьютеру. На контроллер возложена вся работа по обмену данными между компьютером и HDD. Физически контроллер HDD может быть выполнен в виде отдельной платы, вставляемой в слот расширения материнской платы компьютера, или же расположен непосредственно на материнской плате. Обычно контроллер HDD используется еще и для управления FDD - к одному контроллеру подключаются дисководы для жёстких дисков и дисководы для флоппи-дисков.

 

логический диск программа анализ

Рис.1.

 

Любой жёсткий диск (рис.1.) в можно представить как огромный "чистый лист”, на который можно записывать данные и от туда потом их можно считать. Чтобы ориентироваться на диске, всё его пространство разбивают на небольшие "клеточки” - сектора. Сектор - это минимальная единица хранения данных на диске, обычно его размер составляет 512 байт. Все сектора на диске нумеруются: каждый из n секторов получает номер от 0 до n-1. Благодаря этому любая информация, записанная на диск, получает точный адрес - номера соответствующих секторов. Так что диск ещё можно представить как очень длинную строчку (ленточку) из секторов.

Кластер - состоит из одного или более секторов. Количество секторов зависит от типа диска. Многие жесткие диски имеют кластеры из четырех секторов 2048 байтов. Поиск кластеров вместо отдельных секторов сокращает издержки по времени.

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

 

Рис. 2.


Глава II. Технологический раздел

 

В данной курсовой работе используются следующие заголовочные файлы.

Заголовочные файлы

 

<dir. h>-используется структурой struct dfree free, для получения информации о дисках;

<iostream. h>-используется для ввода\вывода информации на экран;

<graphics. h>-используется для подключения графики;

<bios. h>-используется для получения информации о нажатии клавиш;

<conio. h>-используется для вывода форматированного текста, цвета, фона, чистки и задержки экрана;

<stdio. h>-используется для вывода информации;

<dos. h>-получение информации о кластерах;

Собственные подпрограммы

 

getdisk () - используется для получения информации о диске, файл dos. h содержит такое описание этой функции:

unsigned _dos_getdiskfree (unsigned drive,

struct diskfree_t *diskspace);.

Параметр drive задает номер используемого устройства: 0 - текущий, 1 - А:,2-В:, 3-С: и т.д. Информация возвращается в структуре dfree free, которая определена также в файле dos. hdfree free;

{df_avail - количество свободных кластеров на дискеdf_total - общее количество кластеров на диске unsigned df_bsec-размер сектора в байтахdf_sclus-количество секторов, занимаемых одним кластером.

Для получения общего размера диска, перемножаем значения

total= (long) free. df_total

* (long) free. df_bsec

* (long) free. df_sclus;total-переменная хранящая общий размер диска;

Для получения свободного размера диска, перемножаем значения

avail= (long) free. df_avail

* (long) free. df_bsec

* (long) free. df_sclus;avail-переменная хранящая свободное место на диске;text_info ti-отвечает за цвет фона, координатное

расположение окна и стиль текста выводимого на экран;

_setcursortype (_NOCURSOR) - выключает курсор;(10, 20) - задаёт кордиты окна по х и у;(0x04f) - определяет цвет текста;

 

Указанная ниже подпрограмма осуществляет вычисления и подсчёты для диаграммы и её вывод на экранюkrdiagr (char* *name, float *procent) - Переменная *name - отвечает за вывод на экран надписей "свободно” и "занято”. Переменная *procent - хранит в себе информацию о процентном соотношении свободного и занятого размера на диске. В начале находим сумму занятого и свободного места на диске. Далее находим отдельно процент занятого и свободного размера диска, для этого нужно размер занятого пространства поделить на сумму занятого и свободного размера диска, потом умножить на 100 (сто), такую же процедуру повторяем с размером диска свободного пространства и получаем процентное соотношение. Далее нужно вычислить градусное соотношение, которое будет применяться для круговой диаграммы. Для этого необходимо 3.6 (три целых шесть десятых) умножить на процент занятого пространства диска и тогда получим градусы занятого размера диска. Такую же операцию проделываем со свободным пространством диска. Нашли градусы обеих размеров диска:

 

pieslice (x,y,a1,a2,100) - осуществляет вывод круговой диаграммы,

где x,y - координаты диаграммы; а1, а2 - переменные хранящие градусы, где а1 - начало, а2-конец; 100 - радиус диаграммы.(SOLID_FILL,color [i]) - определяет стиль диаграммы, где SOLID_FILL - стиль заливки, стандартный, color - цвет заливки, i - счетчик.CLEAR () - чистит монитор;

{ window (10,6,70, 20); - координаты окна;(0x0f); - задаёт чёрный цвет;(); - чистит;

}SOUND () - нажатие клавиш вверх/вниз сопровождает звуковым сигналом;

{(100); - звук;(100); - его длительность 1 секунда;(); - останавливает звук;

}OUTPUT (int p1, int p2, int p3, int p4) - выводит меню на экран, делает опрос клавиатуры, при нажатии клавиш управления курсором (вверх, вниз) перемещает цветовой курсор по пунктам меню, выбирает определённый пункт меню при нажатии клавиши, где р1,р2,р3,р4-меняют цвет текста в меню, по нажатию необходимых клавиш;

сprintf - выводит текст;(10, 20,70, 20); - координаты окна в меню;

Меню сделано через цикл switch (), ниже приведен отрывок испол4ьзования switch ();

switch (count)

{ case 1: OUTPUT (0x4f,0x1f,0x1f,0x1f);(10, 20);("Informacia ob aftore programmi");(key==0x1c0d) - если нажата клавиша "Enter”

{ CLEAR (); - чистит экран;("Babii Alexandr 11.05.1993"); - выводит на экран;

};


Заключение

 

В ходе выполнения данной курсовой работы были освоены и закреплены навыки разработки программного обеспечения на языке С++, в среде разработки Borland C++ 3.1 Цель курсовой была частично достигнута, так как среда разработки Borland C++ 3.1 была разработана в 1992 году. На тот момент не существовало жёстких дисков с такими огромными объёмами вмещавших в себя столько информации, сколько вмещают нынешние жёсткие диски. Поэтому разработанная в курсовой работе программа с помощью Borland C++ 3.1 не способна определить размер жёсткого диска обладающим объёмом более 4-х гигабайт, следовательно не реально получить точную информацию о кластерах и секторах на жёстком диске объёмом более 4-х гигабайт. Программа с точностью выводит всю информацию о флоппи-дисках, но с каждым днём флоппи-диски теряют свою актуальность, они уже редко встречаются в магазинах, возможно в дальнейшем будущем они станут дефицитными. На замену флоппи-дискам пришли флешки. Флешки обладают большими объёмами, и они удобные. Остальные цели данного курсового проекта были полностью достигнуты, разработано удобное меню с помощью которого упростился диалог пользователя с машиной. Выводится круговая диаграмма, основанная на вычислениях из чисел, свободного и занятого пространства на диске. Освоена работа с процентным соотношением этих величин.


Список литературы

 

1. Методичка С++

 


Приложение

 

#include<dir. h>

#include<iostream. h>

#include<graphics. h>

#include<bios. h>

#include<conio. h>

#include<stdio. h>

#include<process. h>

#include<dos. h>

#include<stdlib. h>

#include <math. h>

#define N 2krdiagr (char* *name,float *procent); // диаграммаout (); // справка о программеSOUND (); // звукOUTPUT (int p1, int p2, int p3, int p4); // цвета и текст меню

void CLEAR (); // очистка экранаmain () /

{();count=1; // счётчикkey; // переменная хранит нажатие клавиш

_setcursortype (_NOCURSOR); // выключаем курсор(count<=4) // цикл

{ if (bioskey (1)! =0) key=bioskey (0);(10,6,70, 20); // формат окна(BLUE); // цвет окна(); // очистка экрана(count) // цикл для меню

{ case 1: OUTPUT (0x4f,0x1f,0x1f,0x1f); // вызывает подпрограмму OUTPUT(10, 20); // координаты текста("Informacia ob aftore programmi"); // выводит текст по координатам(key==0x1c0d) // если нажали "Enter”

{ CLEAR (); // вызывает подпрограмму чистки экрана("Babii Alexandr 11.05.1993"); // выводим текст

}; // обрываем цикл2: OUTPUT (0x1f,0x4f,0x1f,0x1f); // вызывает подпрограмму OUTPUT(10, 20); // координаты текста("Informacia o tekuwem diske\ "); // выводит текст ниже окна

if (key==0x1c0d) // если "Enter”

{ CLEAR (); // вызывает подпрограмму чистки экранаgdriver = DETECT, gmode, errorcode; // инициализация графикиmidx, midy;(&gdriver, &gmode, "");=graphresult ();(errorcode! = grOk)

{("Graphics error: %s\n", grapherrormsg (errorcode));("Press any key to halt: ");

getch ();(1);

}dfree free; // структура содержит информацию о дискахavail; // переменная хранящая число свободного местаdrive; // переменная хранящая текущий диск

drive=getdisk ();(drive+1, &free);(free. df_sclus == 0xFFFF)

{("Error in getdfree () call\n");(1);

}= (long) free. df_avail // свободные кластеры

* (long) free. df_bsec // байты в секторе

* (long) free. df_sclus; // секторы в кластере

printf ("Tekuwii disk----------------------------| %c: \n", 'A' + drive, avail);

long total; // переменная хранящая общий размер диска=getdisk (); // получаем букву текущего диска

getdfree (drive+1,&free);(free. df_sclus==0xFFFF)

{("Error in getdfree () call\n");(1);

}= (long) free. df_total // общие кластеры

* (long) free. df_bsec // байты в секторе

* (long) free. df_sclus; // секторы в кластере

printf ("\Obwee koli4estvo klasterov na diske: - ---|%u"

"\nKoli4estvo svobodnix klasterov: - --------|%u"

"\nKoli4estvo sektorov v klastere: - --------|%u"

"\nKoli4estvo bait v sektore: - -------------|%u"

"\n",. df_total,free. df_avail,free. df_sclus,free. df_bsec);("Obwii razmer disca %c: %lu mb\n",'A'+drive,total/1024/1024);("Svobodnoe mesto disca %c: %lu mb\n",'A'+drive,avail/1024/1024);

long zaniato=total-avail;("Zaniatoe mesto disca %c: %lu mb\n",'A'+drive,zaniato/1024/1024);

char *name [N] ={"Zaniato\0","Svobodno\0"}; // символьная строка хранит названия местrazmer [N]; // размерыprocent [N]; // процентыsum=0; // суммаi; // временная используется в цикле как счетчик для нахождения сумм[0] =zaniato; // размер занятого места[1] =avail; // размер свободного места(i=0; i<N; i++)

{+=razmer [i]; // сумма обеих размеров (величин)

}(i=0; i<N; i++) // цикл[i] =razmer [i] /sum*100; // находит проценты(name,procent); // вызывает подпрограмму вывода диаграммы(); // задержка экрана(); // закрываем графику

}; // обрываем цикл3: OUTPUT (0x1f,0x1f,0x4f,0x1f);(10, 20); // координаты начала расположения окна и текста("Spravka o programme"); // вывод на экран(key==0x1c0d) // если нажата клавиша "Enter" выходим из программы

{(); // вызываем подпрограмму чистки экрана(); // вызываем подпрограмму вывода текста

}; // обрываем цикл4: OUTPUT (0x1f,0x1f,0x1f,0x4f);(10, 20); // координаты начала расположения окна и текста("Vixod"); // выводим на экран(key==0x1c0d) return 0; // если нажата клавиша "Enter" выходим из программы

break; // обрываем цикл: break;

}=bioskey (0);(key ==0x5000) // если нажата клавиша вниз

{ SOUND (); // вызываем подпрограмму звука(count==4) count = 1; // если счетчик равен 4, придаем ему значение 1count++; // иначе сдвигаем вперед (вправо)

}(key ==0x4800) // если нажата клавиша вверх

{ SOUND (); // вызываем подпрограмму звука(count==1) count = 4; // если счетчик равен 1, придаем ему значение 4count--; // иначе сдвигаем его назад (влево)

}(key==0x11b) return 0; // если нажата клавиша "Esc" выходим из программы

}0;

}SOUND () // звук

{(100); // частота

delay (100); // длительность 1 секунда(); // выключает звук

return 0; // возвращает ноль

}OUTPUT (int p1, int p2, int p3, int p4)

{ clrscr ();(p1);("Aftor programmi\n\r");(p2);("Disk\n\r");(p3);("HELP\n\r");(p4);("Vixod");(10, 20,70, 20); // координаты окна

textattr (0x04f); // фон синий, текст белый(); // чистит экран

}CLEAR ()

{ window (10,6,70, 20); // координаты окна(0x0f); // цвет текста (фон чёрный, текст белый)

clrscr (); // чистит экран

}out ()

{("Dlia upravlinia programmoi ispolzuite klaviwi '%c' i '%c', dlia vibora 'Enter'. Dlia vixoda ispolzuite 'Esc'.", 24, 25); // выводит текст на экран0; // возвращает ноль

}krdiagr (char* *name,float* procent)

{a1,a2; // начало и конец диаграммы в градусахcolor [2] ={RED,BLUE}; // цвета для диаграммы и квадратиковx,y; // переменные хранящие координаты квадратиковi; // переменная используется в цикле для определения соответствующих цветов=0; // начало диаграммы равно нулю=10; y=130; // координаты размещения квадратиков(i=0; i<N; i++) // цикл

{=a1+3.6*procent [i]; // вычисляет градусы(i==N-1) // условие=360; // конец диаграммы(SOLID_FILL,color [i]); // стиль диаграммы

// sector (200, 200,a1,a2,100,100);(280,280,a1,a2,100); // вывод диаграммы=a2;

printf (" %s-%f %\n",name [i],procent [i]);

bar (x,y,x+30,y+10); // вывод квадратиков+=16; // промежуток между квадратиками

}

}

Поделиться:





Воспользуйтесь поиском по сайту:



©2015 - 2024 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...