-->

Основы программирования в Linux

На нашем литературном портале можно бесплатно читать книгу Основы программирования в Linux, Мэтью Нейл-- . Жанр: Программирование / ОС и Сети. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале bazaknig.info.
Основы программирования в Linux
Название: Основы программирования в Linux
Дата добавления: 16 январь 2020
Количество просмотров: 669
Читать онлайн

Основы программирования в Linux читать книгу онлайн

Основы программирования в Linux - читать бесплатно онлайн , автор Мэтью Нейл
В четвертом издании популярного руководства даны основы программирования в операционной системе Linux. Рассмотрены: использование библиотек C/C++ и стан­дартных средств разработки, организация системных вызовов, файловый ввод/вывод, взаимодействие процессов, программирование средствами командной оболочки, создание графических пользовательских интерфейсов с помощью инструментальных средств GTK+ или Qt, применение сокетов и др. Описана компиляция программ, их компоновка c библиотеками и работа с терминальным вводом/выводом. Даны приемы написания приложений в средах GNOME® и KDE®, хранения данных с использованием СУБД MySQL® и отладки программ. Книга хорошо структурирована, что делает обучение легким и быстрым. Для начинающих Linux-программистов

Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала

1 ... 43 44 45 46 47 48 49 50 51 ... 324 ВПЕРЕД
Перейти на страницу:

Имя открываемого файла или устройства передается как параметр

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 с правом на чтение для владельца и правом на выполнение для остальных и только с этими правами доступа.

$ <b>ls -ls myfile</b>

0 -r-------х 1 neil software 0 Sep 22 08:11 myfile*

Есть пара факторов, способных повлиять на права доступа к файлу. Во-первых, заданные права применяются, только если файл создается. Во-вторых, на права доступа к созданному файлу оказывает воздействие маска пользователя (заданная командой командной оболочки,

umask
). Значение параметра
mode
, заданное в вызове
open
, на этапе выполнения объединяется с помощью операции
AND
с инвертированной маской пользователя. Например, если заданы маска пользователя 001 и в параметре
mode
флаг
S_IXOTH
, у созданного файла не будет права на выполнение для "остальных", т.к. маска пользователя указывает на то, что это право не должно предоставляться. Флаги в вызовах
open
и
creat
являются на самом деле запросами на установку прав доступа. Будут ли предоставлены запрошенные права, зависит от значения
umask
во время выполнения.

umask

umask
— это системная переменная, содержащая маску для прав доступа к файлу, которые будут применяться при создании файла. Вы можете изменить значение переменной, выполнив команду
umask
, предоставляющую новое значение. Значение этой переменной представляет собой трёхзнаковое восьмеричное число. Каждая цифра — результат объединения с помощью операций
OR
значений 1, 2 или 4 (табл. 3.2). Отдельные цифры указывают на права доступа "пользователя", "группы" и "остальных" соответственно.

1 ... 43 44 45 46 47 48 49 50 51 ... 324 ВПЕРЕД
Перейти на страницу:
Комментариев (0)
название