Нейл Мэтью - Основы программирования в Linux
- Название:Основы программирования в Linux
- Автор:
- Жанр:
- Издательство:«БХВ-Петербург»
- Год:2009
- Город:Санкт-Петербург
- ISBN:978-5-9775-0289-4
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Нейл Мэтью - Основы программирования в Linux краткое содержание
В четвертом издании популярного руководства даны основы программирования в операционной системе Linux. Рассмотрены: использование библиотек C/C++ и стандартных средств разработки, организация системных вызовов, файловый ввод/вывод, взаимодействие процессов, программирование средствами командной оболочки, создание графических пользовательских интерфейсов с помощью инструментальных средств GTK+ или Qt, применение сокетов и др. Описана компиляция программ, их компоновка c библиотеками и работа с терминальным вводом/выводом. Даны приемы написания приложений в средах GNOME® и KDE®, хранения данных с использованием СУБД MySQL® и отладки программ. Книга хорошо структурирована, что делает обучение легким и быстрым.
Для начинающих Linux-программистов
Основы программирования в Linux - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Однако сигналы, захватываемые обработчиками, заданными в структуре sigaction
, по умолчанию не восстанавливаются, и нужно задать в поле sa_flags
значение SA_RESETHAND
, если хотите добиться поведения, виденного вами раньше при обсуждении функции signal
. Прежде чем обсуждать подробнее sigaction
, давайте перепишем программу ctrlc.c, применяя sigaction
вместо функции signal
(упражнение 11.9).
sigaction
Внесите приведенные далее изменения, так чтобы сигнал SIGINT
перехватывался sigaction
. Назовите новую программу ctrlc2.c.
#include
#include
#include
void ouch(int sig) {
printf("OUCH! - I got signal %d\n", sig);
}
int main() {
struct sigaction act;
act.sa_handler = ouch;
sigemptyset(&act.sa_mask);
act.sa_flags = 0;
sigaction(SIGINT, &act, 0);
while (1) {
printf("Hello World!\n");
sleep(1);
}
}
Когда вы выполните эту версию программы, то всегда будете получать сообщение при нажатии комбинации клавиш +, поскольку SIGINT
обрабатывается неоднократно функцией sigaction
. Для завершения программы следует нажать комбинацию клавиш +<\>, которая генерирует по умолчанию сигнал SIIGQUIT
.
$ ./ctrlc2
Hello World!
Hello World!
Hello World!
^C
OUCH! - I got signal 2
Hello World!
Hello World!
^C
OUCH! - I got signal 2
Hello World!
Hello World!
^\
Quit
$
Как это работает
Программа вместо функции signal
вызывает sigaction
для задания функции ouch
как обработчика сигнала, возникающего при нажатии комбинации клавиш + ( SIGINT
). Прежде всего, она должна определить структуру sigaction
, содержащую обработчик, маску сигналов и флаги, В данном случае вам не нужны никакие флаги, и создается пустая маска сигналов с помощью новой функции sigemptyset
.
После выполнения программы вы можете обнаружить дамп ядра (в файле core). Его можно безбоязненно удалить.
Множества сигналов
В заголовочном файле signal.h определены тип sigset_t
и функции, применяемые для манипулирования множествами сигналов. Эти множества используются в sigaction
и других функциях для изменения поведения процесса при получении сигналов.
#include
int sigaddset(sigset_t *set, int signo);
int sigemptyset(sigset_t *set);
int sigfillset(sigset_t *set);
int sigdelset(sigset_t *set, int signo);
Приведенные функции выполняют операции, соответствующие их названиям, sigemptyset
инициализирует пустое множество сигналов. Функция sigfillset
инициализирует множество сигналов, заполняя его всеми заданными сигналами, sigaddset
и sigdelset
добавляют заданный сигнал ( signo
) в множество сигналов и удаляют его из множества. Они все возвращают 0 в случае успешного завершения и -1 в случае ошибки, заданной в переменной errno
. Единственная определенная ошибка EINVAL
описывает сигнал как некорректный.
Функция sigismember
определяет, включен ли заданный сигнал в множество сигналов. Она возвращает 1, если сигнал является элементом множества, 0, если нет и -1 с errno
, равной EINVAL
, если сигнал неверный.
#include
int sigismember(sigset_t *set, int signo);
Маска сигналов процесса задается и просматривается с помощью функции sigprocmask
. Маска сигналов — это множество сигналов, которые заблокированы в данный момент и не будут приниматься текущим процессом.
#include
int sigprocmask(int how, const sigset_t *set, sigset_t *oset);
Функция sigprocmask
может изменять маску сигналов процесса разными способами в соответствии с аргументом how
. Новые значения маски сигналов передаются в аргументе set
, если он не равен null
, а предыдущая маска сигналов будет записана в множество сигналов oset
.
Аргумент how
может принимать одно из следующих значений:
□ SIG_BLOCK
— сигналы аргумента set
добавляются к маске сигналов;
□ SIG_SETMASK
—маска сигналов задается аргументом set
;
□ SIG_UNBLOCK
— сигналы в аргументе set
удаляются из маски сигналов.
Если аргумент set
равен null
, значение how
не используется и единственная цель вызова — перенести значение текущей маски сигналов в аргумент oset
.
Если функция sigprocmask
завершается успешно, она возвращает 0. Функция вернет -1, если параметр how
неверен, в этом случае переменная errno
будет равна EINVAL
.
Если сигнал заблокирован процессом, он не будет доставлен, но останется ждать обработки. Программа может определить с помощью функции sigpending
, какие из заблокированных ею сигналов ждут обработки.
#include
int sigpending(sigset_t *set);
Она записывает множество сигналов, заблокированных от доставки и ждущих обработки, в множество сигналов, на которое указывает аргумент set
. Функция возвращает 0 при успешном завершении и -1 в противном случае с переменной errno
, содержащей ошибку. Данная функция может пригодиться, когда программе потребуется обрабатывать сигналы и управлять моментом вызова функции обработки.
С помощью функции sigsuspend
процесс может приостановить выполнение, пока не будет доставлен один сигнал из множества сигналов. Это более общая форма функции pause
, с которой вы уже встречались.
#include
int sigsuspend(const sigset_t *sigmask);
Функция sigsuspend
замещает маску сигналов процесса множеством сигналов, заданным в аргументе sigmask
, и затем приостанавливает выполнение. Оно будет возобновлено после выполнения функции обработки сигнала. Если полученный сигнал завершает программу, sigsuspend
никогда не вернет ей управление. Если полученный сигнал не завершает программу, sigsuspend
вернет с переменной errno
, равной EINTR
.
Поле sa_flags
структуры sigaction
, применяемой в функции sigaction
, может содержать значения, изменяющие поведение сигнала (табл. 11.5).
Интервал:
Закладка: