Нейл Мэтью - Основы программирования в Linux
- Название:Основы программирования в Linux
- Автор:
- Жанр:
- Издательство:«БХВ-Петербург»
- Год:2009
- Город:Санкт-Петербург
- ISBN:978-5-9775-0289-4
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Нейл Мэтью - Основы программирования в Linux краткое содержание
В четвертом издании популярного руководства даны основы программирования в операционной системе Linux. Рассмотрены: использование библиотек C/C++ и стандартных средств разработки, организация системных вызовов, файловый ввод/вывод, взаимодействие процессов, программирование средствами командной оболочки, создание графических пользовательских интерфейсов с помощью инструментальных средств GTK+ или Qt, применение сокетов и др. Описана компиляция программ, их компоновка c библиотеками и работа с терминальным вводом/выводом. Даны приемы написания приложений в средах GNOME® и KDE®, хранения данных с использованием СУБД MySQL® и отладки программ. Книга хорошо структурирована, что делает обучение легким и быстрым.
Для начинающих Linux-программистов
Основы программирования в Linux - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Имя открываемого файла или устройства передается как параметр path
; параметр oflags
применяется для указания действий, предпринимаемых при открытии файла.
Параметр oflags
задается как комбинация обязательного режима доступа к файлу и других необязательных режимов. Системный вызов open
должен задавать один из режимов доступа к файлу, указанных в табл. 3.1.
Таблица 3.1
Режим | Описание |
---|---|
О_RDONLY |
Открытие только для чтения |
О_WRONLY |
Открытие только для записи |
O_RDWR |
Открытие для чтения и записи |
Вызов может также включать в параметр oflags
комбинацию (с помощью побитовой операции OR
) следующих необязательных режимов:
□ O_APPEND
— помещает записываемые данные в конец файла;
□ O_TRUNC
— задает нулевую длину файла, отбрасывая существующее содержимое;
□ O_CREAT
— при необходимости создает файл с правами доступа, заданными в параметре mode
;
□ O_EXCL
— применяется с режимом O_CREAT
, который гарантирует, что вызывающая программа создаст файл. Вызов open
атомарный, т.е. он выполняется только одним вызовом функции. Это предотвращает одновременное создание файла двумя программами. Если файл уже существует, open
завершится неудачно.
Другие возможные значения параметра oflags
описаны на странице интерактивного справочного руководства, посвященной open; ее можно найти в разделе 2 руководства (примените команду man 2 open
).
Вызов open
возвращает новый дескриптор файла (всегда неотрицательное целое) в случае успешного завершения или -1 в случае неудачи, в последнем случае open также задает глобальную переменную errno
,чтобы показать причину неудачи. Мы рассмотрим errno
более подробно в одном из последующих разделов. У нового дескриптора файла всегда наименьший неиспользованный номер дескриптора, свойство, которое может оказаться очень полезным в некоторых обстоятельствах. Например, если программа закрывает свой стандартный вывод, а затем снова вызывает open, будет повторно использован дескриптор файла с номером 1 и стандартный вывод будет успешно перенаправлен в другой файл или на другое устройство.
Существует также системный вызов creat
, стандартизованный POSIX, но он применяется не часто. Он не только создает файл, как можно ожидать; но также и открывает его. Такой вызов эквивалентен вызову open
с параметром oflags
, равным O_CREAT|О_WRONLY|O_TRUNC
.
Количество файлов, одновременно открытых в любой выполняющейся программе, ограничено. Предельное значение обычно определяется константой OPEN_MAX
в файле limits.h и меняется от системы к системе, но стандарт POSIX требует, чтобы оно было не меньше 16. Это значение само по себе может быть ограничено в соответствии с предельными значениями локальной системы, поскольку программа не сможет всегда иметь возможность держать открытыми такое количество файлов. В ОС Linux это предельное значение можно изменять во время выполнения и поэтому OPEN_MAX
уже не константа. Как правило, ее начальное значение равно 256.
Исходные права доступа
Когда вы создаете файл, применяя флаг O_CREAT
в системном вызове open, вы должны использовать форму с тремя параметрами. Третий параметр mode
формируется из флагов, определенных в заголовочном файле sys/stat.h и соединенных поразрядной операцией OR
. К ним относятся:
□ S_IRUSR
— право на чтение, владелец;
□ S_IWUSR
— право на запись, владелец;
□ S_IXUSR
— право на выполнение, владелец;
□ S_IRGRP
— право на чтение, группа;
□ S_IWGRP
— право на запись, группа;
□ S_IXGRP
— право на выполнение, группа;
□ S_IROTH
— право на чтение, остальные;
□ S_IWOTH
— право на запись, остальные;
□ S_IXOTH
— право на выполнение, остальные.
Например, вызов
open("myfile", O_CREAT, S_IRUSR|S_IXOTH);
в результате приведет к созданию файла с именем myfile с правом на чтение для владельца и правом на выполнение для остальных и только с этими правами доступа.
$ ls -ls myfile
0 -r-------х 1 neil software 0 Sep 22 08:11 myfile*
Есть пара факторов, способных повлиять на права доступа к файлу. Во-первых, заданные права применяются, только если файл создается. Во-вторых, на права доступа к созданному файлу оказывает воздействие маска пользователя (заданная командой командной оболочки, umask
). Значение параметра mode
, заданное в вызове open
, на этапе выполнения объединяется с помощью операции AND
с инвертированной маской пользователя. Например, если заданы маска пользователя 001 и в параметре mode
флаг S_IXOTH
, у созданного файла не будет права на выполнение для "остальных", т.к. маска пользователя указывает на то, что это право не должно предоставляться. Флаги в вызовах open
и creat
являются на самом деле запросами на установку прав доступа. Будут ли предоставлены запрошенные права, зависит от значения umask
во время выполнения.
umask
— это системная переменная, содержащая маску для прав доступа к файлу, которые будут применяться при создании файла. Вы можете изменить значение переменной, выполнив команду umask
, предоставляющую новое значение. Значение этой переменной представляет собой трёхзнаковое восьмеричное число. Каждая цифра — результат объединения с помощью операций OR
значений 1, 2 или 4 (табл. 3.2). Отдельные цифры указывают на права доступа "пользователя", "группы" и "остальных" соответственно.
Таблица 3.2
Цифра | Значение | Смысл |
---|---|---|
1 | 0 | Никакие права пользователя не отвергнуты |
4 | Право пользователя на чтение отвергается | |
2 | Право пользователя на запись отвергается | |
1 | Право пользователя на выполнение отвергается | |
2 | 0 | Никакие права группы не отвергнуты |
4 | Право группы на чтение отвергается | |
2 | Право группы на запись отвергается | |
1 | Право группы на выполнение отвергается | |
3 | 0 | Никакие права остальных не отвергнуты |
4 | Право остальных на чтение отвергается | |
2 | Право остальных на запись отвергается | |
1 | Право остальных на выполнение отвергается |
Например, для блокирования права "группы" на запись и выполнение и права "остальных" на запись переменная umask должна была бы быть следующей (табл. 3.3).
Таблица 3.3
Цифра | Значение |
---|---|
1 | 0 |
2 | 2 |
1 | |
3 | 2 |
Значения каждой цифры объединяются операциями OR
, поэтому для получения значения второй цифры нужна операция 2 | 1
, дающая в результате 3
. Результирующее значение umask
— 032.
Интервал:
Закладка: