Методические указания по выполнению курсовых работ по дисциплине «Системное программное обеспечение» для студентов, обучающихся по специальностям 210100, 210200 и направлению 550200 icon

Методические указания по выполнению курсовых работ по дисциплине «Системное программное обеспечение» для студентов, обучающихся по специальностям 210100, 210200 и направлению 550200


Смотрите также:
Методические указания по выполнению курсовых работ по дисциплине «Системное программное...
В. И. Харитонов > К. И. Меша Одобрено методической > С. С...
Методические указания по выполнению, представлению и защите курсовых работ для специальности...
Методические указания по выполнению курсовых работ по дисциплине «Экономический анализ» для...
Методические указания к выполнению лабораторных работ по курсам «Технические средства...
Методические указания к выполнению курсовой и лабораторных работ по дисциплине «Системное...
Методические указания по выполнению курсовых работ для студентов всех форм обучения...
Методические указания по выполнению курсовых работ для студентов специальности спо 032002...
Методические указания по выполнению контрольных работ для студентов...
Методические рекомендации к выполнению курсовых работ по дисциплине «Документоведение»...
Методические указания по выполнению курсовых работ для студентов III курса...
Методические рекомендации по выполнению курсовых работ по дисциплине «Экономическая теория»...



Загрузка...
страницы:   1   2   3   4
скачать


ФЕДЕРАЛЬНОЕ АГЕНТСТВО ПО ОБРАЗОВАНИЮ

Государственное образовательное учреждение

высшего профессионального образования

«Московский государственный технический

университет «МАМИ»


Кафедра «Автоматика и процессы управления»


Е.Г. Мурачев, И.Ю. Иванов, Ю.А. Савостьянок


МЕТОДИЧЕСКИЕ УКАЗАНИЯ

по выполнению курсовых работ

по дисциплине

«Системное программное обеспечение»


для студентов, обучающихся по специальностям 210100, 210200 и направлению 550200.


Одобрено методической комиссией

по общепрофессиональным дисциплинам


1-е издание


Москва

2010


Разработано в соответствии с Государственным образовательном стандартом ВПО 2000 г. для направления (специальности) подготовки _______ на основе примерной (рабочей) программы дисциплины «Системное программное обеспечение»


Рецензенты: профессор кафедры «Автотракторное электрооборудование» МГТУ «МАМИ» Р.А. Малеев


профессор кафедры «Автомобили» им. Е.А. Чудакова

В.В. Селифонов


Работа подготовлена на кафедре «Автоматика и процессы управления»


Исследование систем автоматического регулирования: методические указания / Е.Г. Мурачев, И.Ю. Иванов, Ю.А.Савостьянок. – 1-е изд. – М. : МГТУ «МАМИ», 2009. – 39 с.


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


© Е.Г. Мурачев, 2009

© И.Ю. Иванов, 2009

© Ю.А.Савостьянок, 2009

© МГТУ «МАМИ», 2009

Введение

Курсовая работа по дисциплине «Системное программное обеспечение» выполняется студентами специальности 210100, 210200 и направления 550200 в 6 семестре. В рамках курсовой работы должно быть разработано приложение для операционной системы UNIX, при выполнении курсовой работы используются знания, полученные студентами при изучении дисциплины «Программирование и основы алгоритмизации», а также дисциплины «Информатика».


СОДЕРЖАНИЕ

Введение 3

Содержание 4

1 Цель и задачи курсового проектирования 5

2 Организация и последовательность выполнения

курсовой работы 6

2.1 Задание на курсовую работу 6

2.2 Объем и содержание курсовой работы 6

2.3 Последовательность выполнения работы 7

3 Варианты заданий 8

4 Информация для выполнения курсовой работы 12

4.1 Демоны 12

4.2 Язык PostScript 14

4.3 Командный интерпретатор 26

Приложения 32

Литература 37


^ 1 ЦЕЛЬ И ЗАДАЧИ КУРСОВОГО ПРОЕКТИРОВАНИЯ

1.1 Целью курсового проектирования является приобретение практических навыков по разработке структуры приложения, алгоритмов и программ для их реализации с использованием языков C++ и PostScript для операционной системы UNIX/Linux.


1.2 Задачей курсовой работы является разработка приложения по
заданным исходным данным:

- разработка программы-демона;

- построение грамматики для заданного языка и автомата для его

распознавания

- построение лексического анализатора;

- разработка программы обработки запроса ядром UNIX для

символьного устройства;

- разработка программы обработки запроса ядром UNIX для блочного

устройства;

- разработка программы вывода графиков на языке PostScript;

- разработка программ, использующих системный вызов.

^ 2. ОРГАНИЗАЦИЯ И ПОСЛЕДОВАТЕЛЬНОСТЬ ВЫПОЛНЕНИЯ КУРСОВОЙ РАБОТЫ

Курсовое проектирование является формой самостоятельной работы студента и выполняется по индивидуальному заданию.

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

За правильность проектных решений, качество оформления работы, своевременность выполнения отдельных этапов и представления к защите отвечает студент.


^ 2.1 Задание на курсовую работу


Задание на курсовую работу выбирается студентом по номеру группы и порядковому номеру студента в журнале.


2.2 Объем и содержание курсовой работы


Работа состоит из расчетно-пояснительной записки (РПЗ) и программы, представленной на CD-диске.

Техническое задание включает общие и специальные требования к программе.

Объем пояснительной записки составляет 30-40 машинописных страниц (формат А4), РПЗ должна быть написана четко и кратко, содержать пояснения к разработанному приложению, обоснование принятых решений. РПЗ должна включать следующие разделы:

  1. титульный лист (приложение А),

  2. бланк задания, подписанный преподавателем и студентом (приложение Б),

  3. содержание,

  4. перечень условных обозначений и сокращений в алфавитном порядке в виде списка, в котором слева приводится сокращение, справа – его расшифровка,

  5. основная часть РПЗ:

Краткие теоретические сведения: анализ существующих программ подобного класса; особенности создания приложений для ОС UNIX/Linux;

Разработка структуры приложения;

Разработка алгоритма решения задачи;

Разработка программы;

Проектирование интерфейса приложения (если это предусмотрено заданием на КР);

Заключение;

Список использованных источников;

Приложения:

- спецификация программного обеспечения (приложение В),

- текст программы (приложение Г),

- руководство пользователя (системного программиста) (приложение Д).


^ 2.3 Последовательность выполнения работы


Курсовая работа разрабатывается в последовательности, соответствующей содержанию РПЗ (п. 2.2).

Расчетно-пояснительная записка и графический материал оформляются в соответствии с требованиями ЕСКД и ЕСПД (Единая система конструкторской документации, Единая система программной документации).

Подготовленная и оформленная работа, прошедшая экспертизу на выполнение требований ЕСКД и ЕСПД представляется преподавателю не позднее, чем за неделю до защиты.

Защита работы происходит на 16 или 17 неделе семестра.

^ 3 ВАРИАНТЫ ЗАДАНИЙ


Вариант 1

Написать и отладить программу на языке С++, использующую системные вызовы для управления файлами в среде UNIX (тип файла - обычный, каталоги).

Вариант 2

Написать и отладить программу на языке С++, использующую системные вызовы для управления файлами в среде UNIX (тип файла - специальные, FIFO).

Вариант 3

Разработать на языке PostScript программу вывода графика функции f(), которая строит n периодов, соединяя точки, расположенные с интервалом m°,

отрезками прямых. Размер поля рисования 10x4 см, график расположен в

центре листа и обведен рамкой.


а) f= sin(2а+х), п=4 m=5°

б) f=cos(x), п=3, т=10°

в) f= sin(x)/2, n= 4; т=8°

Вариант 4

Написать процедуру на языке PostScript, которая вдоль ранее созданного графического пути строит штрих - пунктирную линию, состоящую из:

  1. прямоугольных штрихов со срезанными краями и кружков между ними;

  2. двукратное проведение штриховой линии с разными параметрами,..



Вариант 5

Разработать на языке PostScript программу, позволяющую строить различные графические изображения с использованием функций cos() и sin(), не используя при этом встроенные функции языка. Разработка данной программы предполагает вывод изображений функций cos () и sin() одновременно в различных проекциях и пространствах (двумерном, трехмерном), различным цветом, со смещенной системой координат на 90°. Изображения строятся по точкам, расположенным друг от друга с интервалом 5°, 10°, 36°, 126°, 181°, 359°. Для работы с цветом использовать процедуру изменения цвета изображений (по RGB- матрице).


Вариант 6

Написать на языке PostScript файл для печати рекурсивных геометрических объектов:

а) ковра Серпинского;

б) кривых Гильберта;

в) кривых Коха;

г) кривых Пеано.


Вариант 7

Разработать на языке PostScript программу построения и вывода на печать графика заданной функции:


а) f=tg(l+2a)/(a+b);

б) f=exp(3a+2);

в) f=log(1+a/4)/3


Вариант 8

Используя системный вызов stat, напишите программу, определяющую тип файла: обычный файл, каталог, устройство, FIFO-файл.

Вариант 9

Напишите программу удаления файлов и каталогов, заданных в argv. Делайте системный вызов stat, чтобы определить тип файла (файл/каталог). Программа должна отказываться удалять файлы устройств. Для удаления пустого каталога (не содержащего иных имен, кроме "." и "..") следует использовать системный вызов

rmdir(имя_каталога);

(если каталог не пуст - errno получит значение EEXIST); а для удаления обычных файлов (не каталогов)

unlink(имя_файла);

Программа должна запрашивать подтверждение на удаление каждого файла, выдавая его имя, тип, размер в килобайтах и вопрос "удалить ?".

Вариант 10

Напишите функцию печати текущего времени в формате ЧЧ:ММ:СС ДД-МЕС-ГГ. Используйте системный вызов time() и функцию localtime(). Рекомендуется использование стандартной функции ctime().


Вариант 11

Структура stat, заполняемая системным вызовом stat(), кроме прочих полей содержит поля типа time_t st_ctime, st_mtime и st_atime - время последнего изменения содержимого I-узла файла, время последнего изменения файла и время последнего доступа к файлу.

  • Поле st_ctime изменяется (устанавливается равным текущему астрономическому времени) при применении к файлу вызовов creat, chmod, chown, link, unlink, mknod, utime*, write (т.к. изменяется длина файла); Это поле следует рассматривать как время модификации прав доступа к файлу;

  • st_mtime - write, creat, mknod, utime; Это поле следует рассматривать как время модификации содержимого файла (данных);

  • st_atime - read, creat, mknod, utime; Это поле следует рассматривать как время чтения содержимого файла (данных).

Модифицируйте функцию typeOf(), чтобы она печатала еще и эти даты.

utime(имяФайла, NULL);

Он используется для взаимодействия с программой make - в команде touch. Изменить время можно только своему файлу.

Вариант 12

Напишите аналог команды ls -l, выдающий имена файлов каталога и их коды доступа в формате rwxrw-r--. Для получения кодов доступа используйте вызов stat

stat( имяФайла, &st);

кодыДоступа = st.st_mode & 0777;

Для изменения кодов доступа используется вызов

chmod(имя_файла, новые_коды);

Можно изменять коды доступа, соответствующие битовой маске

0777 | S_ISUID | S_ISGID | S_ISVTX

(смотри <sys/stat.h>). Тип файла (см. функцию typeOf) не может быть изменен. Изменить коды доступа к файлу может только его владелец.

Вариант 13

Вот программа, которая каждые 2 секунды проверяет - не изменилось ли содержимое текущего каталога:

#include

#include

extern char *ctime();

main(){

time_t last; struct stat st;

for( stat(".", &st), last=st.st_mtime; ; sleep(2)){

stat(".", &st);

if(last != st.st_mtime){

last = st.st_mtime;

printf("Был создан или удален какой-то файл: %s",

ctime(&last));

}

}

}

Модифицируйте ее, чтобы она сообщала какое имя (имена) было удалено или создано (для этого надо при запуске программы прочитать и запомнить содержимое каталога, а при обнаружении модификации - перечитать каталог и сравнить его с прежним содержимым).

Вариант 14

Вот программа, которая каждые 2 секунды проверяет - не изменилось ли содержимое текущего каталога:

#include

#include

extern char *ctime();

main(){

time_t last; struct stat st;

for( stat(".", &st), last=st.st_mtime; ; sleep(2)){

stat(".", &st);

if(last != st.st_mtime){

last = st.st_mtime;

printf("Был создан или удален какой-то файл: %s",

ctime(&last));

}

}

}


Модифицируйте ее, чтобы она выдавала сообщение, если указанный вами файл был кем-то прочитан, записан или удален. Вам следует отслеживать изменение полей st_atime, st_mtime и значение stat() < 0 соответственно. Если файл удален - программа завершается.


Вариант 15

Современные UNIX-машины имеют встроенные таймеры (как правило несколько) с довольно высоким разрешением. Некоторые из них могут использоваться как "будильники" с обратным отсчетом времени: в таймер загружается некоторое значение; таймер ведет обратный отсчет, уменьшая загруженный счетчик; как только это время истекает - посылается сигнал процессу, загрузившему таймер.

Вот как, к примеру, выглядит функция задержки в микросекундах (миллионных долях секунды). Примечание: эту функцию не следует использовать вперемежку с функциями sleep и alarm.

#include

#include

#include


void do_nothing() {}


/* Задержка на usec миллионных долей секунды (микросекунд) */

void usleep(unsigned int usec) {


struct itimerval new, old;

/* struct itimerval содержит поля:

struct timeval it_interval;

struct timeval it_value;


Где struct timeval содержит поля:

long tv_sec; -- число целых секунд

long tv_usec; -- число микросекунд

*/

struct sigaction new_vec, old_vec;


if (usec == 0) return;


/* Поле tv_sec содержит число целых секунд.

Поле tv_usec содержит число микросекунд.


it_value - это время, через которое В ПЕРВЫЙ раз

таймер "прозвонит",

то есть пошлет нашему процессу

сигнал SIGALRM.


Время, равное нулю, немедленно остановит таймер.


it_interval - это интервал времени, который будет загружаться

в таймер после каждого "звонка"

(но не в первый раз).


Время, равное нулю, остановит таймер

после его первого "звонка".

*/

new.it_interval.tv_sec = 0;

new.it_interval.tv_usec = 0;

new.it_value.tv_sec = usec / 1000000;

new.it_value.tv_usec = usec % 1000000;


/* Сохраняем прежнюю реакцию на сигнал SIGALRM в old_vec,

заносим в качестве новой реакции do_nothing()

*/

new_vec.sa_handler = do_nothing;

sigemptyset(&new_vec.sa_mask);

new_vec.sa_flags = 0;


sighold(SIGALRM);

sigaction(SIGALRM, &new_vec, &old_vec);


/* Загрузка интервального таймера значением new, начало отсчета.

* Прежнее значение спасти в old.

* Вместо &old можно также NULL - не спасать.

*/

setitimer(ITIMER_REAL, &new, &old);


/* Здесь вам необходимо ждать прихода сигнала SIGALRM */


/* Здесь вам необходимо восстановить реакцию на SIGALRM */


/* Здесь вам необходимо восстановить прежние параметры таймера */

}


Задание: в теле функции usleep() опишите функцию setitimer(), которая будет ждать прихода сигнала SIGALRM, восстанавливать реакцию на SIGALRM, восстанавливать прежние параметры таймера.


Вариант 16


Напишите "часы", выдающие текущее время каждые 3 секунды.

Вариант 17

Системный вызов fork() (вилка) создает новый процесс: копию процесса, издавшего вызов. Отличие этих процессов состоит только в возвращаемом fork-ом значении:

0 - в новом процессе.

pid нового процесса - в исходном.

Задание: сделайте так, чтобы вызов fork завершился неудачей, если таблица процессов переполнена.

Вариант 18


Перепишите следующий алгоритм при помощи longjmp. Используйте нелокальный переход вместо цепочки return-ов

#define FOUND 1 /* ответ найден */

#define NOTFOUND 0 /* ответ не найден */

int value; /* результат */

main(){ int i;

for(i=2; i < 10; i++){

printf( "пробуем i=%d\n", i);

if( test1(i) == FOUND ){

printf("ответ %d\n", value); break;

}

}

}

test1(i){ int j;

for(j=1; j < 10 ; j++ ){

printf( "пробуем j=%d\n", j);

if( test2(i,j) == FOUND ) return FOUND;

/* "сквозной" return */

}

return NOTFOUND;

}

test2(i, j){

printf( "пробуем(%d,%d)\n", i, j);

if( i * j == 21 ){

printf( " Годятся (%d,%d)\n", i,j);

value = j; return FOUND;

}

return NOTFOUND;

}

Обратите внимание, что при возврате ответа через второй аргумент longjmp надо прибавить 1, а при печати ответа эту единицу необходимо отнять. Это надо сделать на случай ответа j==0, чтобы функция setjmp не вернула бы в этом случае значение 0 (признак установки контрольной точки).


Вариант 19


Написать программу на С++, выполнение которой позволяет:

создать файл,

считать данные с клавиатуры в буфер;

поместить данные из буфера в созданный файл;

закрыть этот файл;

открыть этот файл и вывести его содержимое на экран монитора, закрыть файл.


Вариант 20


Написать программу на С++, выполнение которой позволяет:

проверить наличие файла на диске;

если файл существует, открыть его. Если файл не существует создать его;

считать данные с клавиатуры в буфер;

поместить данные из буфера в созданный файл;

закрыть этот файл.

Отобразить содержимое файла на экране


Вариант 21


Написать программу на С++, выполнение которой позволяет:

проверить наличие двух файлов на диске;

если файлы существуют, открыть их. Если файлы не существуют, создать их, ввести данные;

перенаправить информацию из одного файла в другой;

закрыть файлы.

Отобразить содержимое файлов на экране.


Вариант 22


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


Вариант 23


Написать программу, определяющую минимальное, максимальное значения элементов одномерного массива. Элементы массива вводятся с клавиатуры с использованием указателей.


Вариант 24


Вывести на экран номер элемента одномерного массива, его значение, адрес ячейки памяти с использованием указателей. Элементы массива вводятся с клавиатуры.


Вариант 25


Написать программу, суммирующую элементы одномерного массива. Элементы массива вводятся с клавиатуры. Ввод данных, обращение к элементам массива осуществляется с помощью указателей.


Вариант 26


Отсортировать элементы массива. Ввод данных осуществляется с использованием указателей.


Вариант 27


Написать программу с использованием переменной типа структура. Ввод/вывод, обращение к элементам структуры осуществляется с помощью указателей.


Вариант 28


Написать программу с использованием операций new, delete (например, просуммировать элементы массива, память под массив распределить динамически).


^ 4 ИНФОРМАЦИЯ ДЛЯ ВЫПОЛНЕНИЯ КУРСОВОЙ РАБОТЫ


Системное программирование (или программирование систем) — род деятельности, заключающийся в работе над системным программным обеспечением.

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

  • программист должен учитывать специфику аппаратной части и другие свойства системы в которой функционирует программа, использовать эти свойства, например, применяя специально оптимизированный для данной архитектуры алгоритм.

  • обычно используется низкоуровневый язык программирования или такой диалект языка программирования, который

    • позволяет функционирование в окружении с ограниченным набором системных ресурсов.

    • работает максимально эффективно и имеет минимальное запаздывание по времени завершения.

    • имеет маленькую библиотеку времени выполнения (RTL) или не имеет её вообще.

    • позволяет прямое управление (прямой доступ) к памяти и управляющей логике.

    • позволяет делать ассемблерные вставки в код.

  • отладка программы может быть затруднена при невозможности запустить её в отладчике из-за ограничений на ресурсы, поэтому может применяться компьютерное моделирование для решения этой проблемы.

Системное программное обеспечение служит для обеспечения эффективной работы аппаратуры компьютера.

К группе системных программ относятся операционные системы, операционные оболочки, утилиты, драйверы, архиваторы, антивирусные и некоторые другие программы.

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

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

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

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

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

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

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

^ Системный вызов в программировании и вычислительной технике — обращение прикладной программы к ядру операционной системы для выполнения какой-либо операции. Современные операционные системы (ОС) предусматривают разделение времени между выполняющимися вычислительными процессами (многозадачность) и разделение полномочий, препятствующее исполняемым программам обращаться к данным других программ и оборудованию. Ядро ОС исполняется в привилегированном режиме работы процессора. Для выполнения межпроцессной операции или операции, требующей доступа к оборудованию, программа обращается к ядру, которое, в зависимости от полномочий вызывающего процесса, исполняет либо отказывает в исполнении такого вызова. С точки зрения программиста системный вызов обычно выглядит как вызов подпрограммы или функции из системной библиотеки. Однако системный вызов как частный случай вызова такой функции или подпрограммы следует отличать от более общего обращения к системной библиотеке, поскольку последнее может и не требовать выполнения привилегированных операций.

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

Традиционным примером структуры является учетная карточка работающего:

"служащий" описывается набором атрибутов таких, как фамилия, имя, отчество (ф.и.о.), адрес, код социального обеспечения, зарплата и т.д. Некоторые из этих атрибутов сами могут оказаться структурами: ф.и.о. Имеет несколько компонент, как и адрес, и даже зарплата. Структуры оказываются полезными при организации сложных данных особенно в больших программах, поскольку во многих ситуациях они позволяют сгруппировать связанные данные таким образом, что с ними можно обращаться, как с одним целым, а не как с отдельными объектами.


Процессы могут обмениваться между собой информацией через файлы. Существуют файлы с необычным поведением - так называемые FIFO-файлы (first in, first out), ведущие себя подобно очереди. У них указатели чтения и записи разделены. Работа с таким файлом напоминает проталкивание шаров через трубу - с одного конца мы вталкиваем данные, с другого конца - вынимаем их. Организация FIFO-файлов идет по принципу «первый пришёл — первый вышел». Операция чтения из пустой "трубы" проиостановит вызов read (и издавший его процесс) до тех пор, пока кто-нибудь не запишет в FIFO-файл какие-нибудь данные. Очередь в программировании используется, как и в реальной жизни, когда нужно совершить какие-то действия в порядке их поступления, выполнив их последовательно. Примером может служить организация событий в Windows. Когда пользователь оказывает какое-то действие на приложение, то в приложении не вызывается соответствующая процедура (ведь в этот момент приложение может совершать другие действия), а ему присылается сообщение, содержащее информацию о совершенном действии, это сообщение ставится в очередь, и только когда будут обработаны сообщения, пришедшие ранее, приложение выполнит необходимое действие.


^ 4.1 С-функции работы с файлами

Изучение и использование С-функций работы с файлами.

Рассмотрим основные системные вызовы, связанные с проведением операций ввода-вывода, которые наиболее часто используются в операционной системе UNIX. Ввод-вывод в ОС UNIX является крайне простой операцией и налагает на пользователя минимум ограничений.




оставить комментарий
страница1/4
Дата23.01.2012
Размер0.67 Mb.
ТипМетодические указания, Образовательные материалы
Добавить документ в свой блог или на сайт

страницы:   1   2   3   4
отлично
  1
Ваша оценка:
Разместите кнопку на своём сайте или блоге:
rudocs.exdat.com

Загрузка...
База данных защищена авторским правом ©exdat 2000-2017
При копировании материала укажите ссылку
обратиться к администрации
Анализ
Справочники
Сценарии
Рефераты
Курсовые работы
Авторефераты
Программы
Методички
Документы
Понятия

опубликовать
Загрузка...
Документы

Рейтинг@Mail.ru
наверх