Операционная система UNIX
Операционная система UNIX читать книгу онлайн
Книга посвящена семейству операционных систем UNIX и содержит информацию о принципах организации, идеологии и архитектуре, объединяющих различные версии этой операционной системы.
В книге рассматриваются: архитектура ядра UNIX (подсистемы ввода/вывода, управления памятью и процессами, а также файловая подсистема), программный интерфейс UNIX (системные вызовы и основные библиотечные функции), пользовательская среда (командный интерпретатор shell, основные команды и утилиты) и сетевая поддержка в UNIX (протоколов семейства TCP/IP, архитектура сетевой подсистемы, программные интерфейсы сокетов и TLI).
Для широкого круга пользователей.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала
Таблица 2.8. Флаги, определяющие режим открытия файла
Флаг | Описание |
---|---|
O_RDONLY | Открыть файл только для чтения |
O_WRONLY | Открыть файл только для записи |
O_RDWR | Открыть файл для чтения и записи |
O_APPEND | Производить добавление в файл, т.е. устанавливать файловый указатель на конец файла перед каждой записью в файл |
O_CREAT | Если указанный файл уже существует, этот флаг не принимается во внимание. В противном случае, создается файл, атрибуты которого установлены по умолчанию (см. разделы "Владельцы файлов" и "Права доступа к файлу" в главе 1), или с помощью аргумента mode |
O_EXCL | Если указан совместно с O_CREAT, то вызов open(2) завершится с ошибкой, если файл уже существует |
O_NOCTTY | Если указанный файл представляет собой терминал, не позволяет ему стать управляющим терминалом |
O_SYNC | Все записи в файл, а также соответствующие им изменения в метаданных файла будут сохранены на диске до возврата из вызова write(2) |
O_TRUNC | Если файл существует и является обычным файлом, его длина будет установлена равной 0 |
O_NONBLOCK | Изменяет режим выполнения операций read(2) и write(2) для этого файла на неблокируемый. При невозможности произвести запись или чтение, например, если отсутствуют данные, соответствующие вызовы завершатся с ошибкой EAGAIN |
Если операция открытия файла закончилась удачно, то будет возвращен файловый дескриптор — указатель на файл, использующийся в последующих операциях чтения, записи и т.д. Значение файлового дескриптора определяется минимальным свободным слотом в таблице дескрипторов процесса. Так, если дескрипторы 0 и 2 уже заняты (указывают на открытые файлы), вызов open(2) возвратит значение 1. Это свойство может быть использовано в коде командного интерпретатора при перенаправлении потоков ввода-вывода.
$ <b>runme >/home/andrei/run.log</b>
Фрагмент кода
...
/* Закроем ассоциацию стандартного потока вывода (1)
с файлом (терминалом) */
close(1);
/* Назначим стандартный поток вывода в файл /home/andrei/run.log.
Поскольку файловый дескриптор 1 свободен, мы можем рассчитывать
на его получение. */
fd = open("/home/andrei/run.log",
O_WRONLY | O_CREATE | O_TRUNC);
...
В случае неудачи open(1) возвратит -1, а глобальная переменная
errno
Заметим, что только один из флагов
O_RDONLY
O_WRONLY
O_RDWR
oflag
Флаг
O_SYNC
Флаг
O_NONBLOCK
errno = EAGAIN
Функция creat(2)
Функция служит для создания обычного файла или изменения его атрибутов и имеет следующий вид:
#include <fcntl.h>
int creat(const char *path, mode_t mode);
Как и в случае open(2), аргумент path определяет имя файла в файловой системе, a
mode
□ Если идентификатор группы (GID) создаваемого файла не совпадает с эффективным идентификатором группы (EGID) или идентификатором одной из дополнительных групп процесса, бит SGID аргумента
mode
□ Очищаются все биты, установленные в маске процесса
□ Очищается флаг Sticky bit.
Права доступа к файлу обсуждались в главе 1. Более детальная информация приведена в разделе "Права доступа" этой главы.
Если файл уже существует, его длина сокращается до 0, а права доступа и владельцы сохраняются прежними. Вызов creat(2) эквивалентен следующему вызову функции open(2):
open(path, O_WRONLY | O_CREAT | O_TRUNC, mode);
Функция close(2)
Функция close(2) разрывает связь между файловым дескриптором и открытым файлом, созданную функциями creat(2), open(2), dup(2), pipe(2) или fcntl(2). Функция имеет вид:
#include <unistd.h>
int close(int fildes);
В случае успеха close(2) возвращает нулевое значение, в противном случае возвращается -1, а значение переменной
errno
Многие программы явно не используют close(2) при завершении выполнения. Дело в том, что функция exit(2), вызываемая явно или неявно при завершении выполнения программы, автоматически закрывает открытые файлы.
Функции dup(2) и dup2(2)
Функция dup(2) используется для дублирования существующего файлового дескриптора:
int dup(int fildes);
Файловый дескриптор
fildes
fildes