- •Конспект лекций по дисциплине «операционные системы»
- •Лекция № 1. Основные понятия
- •Лекция № 2. Классификация операционных систем
- •Лекция № 3. Процессы
- •Лекция № 4. Управление ресурсами
- •Лекция № 5. Файловые системы
- •Лекция № 6. Архитектура операционных систем
- •Лекция № 7. Сравнение операционных систем
- •7.1. Схема исторических связей между операционными системами
- •7.2. Семейство операционных систем unix
- •7.3. Операционная система vms
- •Лекция № 8. Операционные системы MacOs и BeOs
- •8.1. Операционная система MacOs
- •8.2. Операционная система BeOs
- •Лекция № 9. Операционные системы фирмы ibm: os/2, mvs и vm/cms
- •9.1. Операционная система os/2
- •9.2. Операционная система mvs
- •9.3. Операционная система vm/cms
- •Лекция № 10. Операционные системы qnx и Linux
- •10.1. Операционная система реального времени qnx
- •10.2. Операционная система Linux
- •Лекция № 11. Операционные системы фирмы microsoft
- •11.1. Операционная система dos
- •Лекция № 12. Введение в системное программирование
- •12.1. Основные понятия
- •12.2. Использование командной строки
- •12.3. Копирование файла с использованием стандартной библиотеки языка c
- •12.4. Копирование файла с использованием Windows
- •12.5. Копирование файла с использованием вспомогательной функции Windows
- •12.6. О целесообразности использования стандартной библиотеки с
- •Лекция № 13. Операции открытия, чтения, записи и закрытия файлов
- •13.1. Создание и открытие файла
- •13.2. Закрытие файла
- •13.3. Чтение файла
- •13.4. Запись в файл
- •Лекция № 14. Организация программных потоков
13.4. Запись в файл
Запись в файл выполняется с помощью следующей функции:
BOOL WritedFile (
HANDLE hFile,
LPCVOID lpBuffer,
DWORD nNumberOfBytesToWrite,
LPDWORD lpNumberOfBytesWritten,
LPOVERLAPPED lpOverlapped)
Возвращаемое значение: в случае успешного выполнения – TRUE, иначе – FALSE.
Все параметры этой функции вам уже знакомы. Заметьте, что успешное выполнение записи еще не говорит о том, что данные действительно оказались записанными на диск, если только при создании файла с помощью функции СгеateFile не был использован флаг FILE_FLAG_WRITE_THROUGH. Если во время вызова функции указатель файла был позиционирован в конце файла, Windows увеличит длину существующего файла.
Функции ReadFileGather и WriteFileGather позволяют выполнять операции чтения и записи с использованием набора буферов различного размера.
Лекция № 14. Организация программных потоков
Рассмотрим простейший пример, в котором необходимо подсчитать количество пробелов в текстовых файлах, имена которых должны указываться в командной строке.
Поскольку нас интересует работа с параллельными задачами, пусть при выполнении программы для каждого из перечисленных в командной строке файлов создается свой процесс (или поток выполнения), который параллельно с другими процессами (потоками) производит работу по подсчету пробелов в «своем» файле. Результатом работы программы будет являться список файлов с подсчитанным количеством пробелов для каждого.
Приведенная ниже реализация программы решения данной задачи не является единственно возможной. В данном случае рассматривается наиболее характерный вариант.
Основная программа запускает потоки и ждет окончания их выполнения. Мы имеем всего один вычислительный процесс, но используем мультизадачные возможности операционной системы Windows.
Листинг 14.1. Подсчет количества пробелов в текстовых файлах
#include <windows.h>
#include <stdio.h>
#include <stdlib.h>
//Название: processFile
//Описание: исполняемый код потока
//Входные параметры: lpFileName – имя файла
//Выходные параметры: нет
DWORD processFile(LPVOID lpFileName) {
HANDLE handle; //дескриптор файла
DWORD numRead, total = 0;
char buf;
//Запрос к ОС на открытие файла (только для чтения)
handle = CreateFile((LPCTSTR)lpFileName, GENERIC_READ,
FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
//Цикл чтения до конца файла
do {
//Чтение одного символа из файла
ReadFile(handle,(LPVOID) &buf, 1, &numRead, NULL);
if (buf == 0x20) total++;
} while (numRead>0);
fprintf(stderr,"( ThreadId: %Lu), File %s, spaces = %d\n",
GetCurrentThreadId(), lpFileName, total);
//Закрытие файла
CloseHandle( handle );
return(0);
}
//Название: main
//Описание: главная программа
//Входные параметры: список имен файлов для обработки
//Выходные параметры: нет
int main( int argc, char *argv[]) {
int i;
DWORD pid;
HANDLE hThrd[255]; //массив ссылок на потоки
//для всех файлов, перечисленных в командной строке
for (i=0; i<(argc-1); i++) {
//запуск потока – обработка одного файла
hThrd[i]=CreateThread( NULL, 0x4000,
(LPTHREAD_START_ROUTINE) processFile,
(LPVOID) argv[i+1], 0, &pid);
fprintf( stdout, "processFile started (HND=%d)\n", hThrd[i]);
}
//ожидание окончания выполнения всех запущенных потоков
WaitForMultipleObjects( argc-1, hThrd, true, INFINITE);
return(0);
}