
- •Часть 4. Локальное взаимодействие процессов
- •Глава 16. Блокирование записей 89
- •12.2. Процессы, потоки и общий доступ к информации
- •12.3. Живучесть объектов ipc
- •12.4. Пространства имен
- •12.5. Действие команд fork, exec и exit на объекты ipc
- •12.6. Комментарии к примерам ipc
- •12.7. Выводы по главе 12
- •12.8. Упражнения по главе 12
- •Глава 13. Именованные и неименованные каналы
- •13.1. Введение
- •13.2. Приложение типа клиент-сервер
- •13.3. Программные каналы
- •13.4. Функции popen и pclose
- •13.5. Именованные каналы (fifo)
- •13.6. Некоторые свойства именованных и неименованных каналов
- •13.7. Один сервер, несколько клиентов
- •13.8. Последовательные и параллельные серверы
- •13.9. Ограничения программных каналов и fifo
- •13.10. Выводы по главе 13
- •13.11. Упражнения по главе 13
- •Глава 14. Программные потоки
- •14.1. Введение
- •14.2. Концепция потоков
- •14.3. Идентификация потоков
- •14.4. Создание потока
- •14.5. Завершение потока
- •Функции управления процессами и потоками
- •14.6. Установка атрибутов потока
- •14.7. Реентерабельность
- •Альтернативные версии функций, безопасные в многопоточной среде
- •14.8. Локальные данные потоков
- •14.9. Принудительное завершение потоков
- •Некоторые точки выхода, определенные стандартом Posix.1
- •14.10. Потоки и сигналы
- •14.11. Выводы по главе 14
- •14.12. Упражнения по главе 14 Глава 15. Средства синхронизации потоков
- •15.1. Введение
- •15.2. Взаимные исключения: установка и снятие блокировки
- •15.2.1. Схема производитель-потребитель
- •15.2.2. Блокирование и опрос
- •15.2.3. Предотвращение тупиковых ситуаций
- •15.3. Условные переменные
- •15.3.1. Ожидание и сигнализация
- •15.3.2. Исключение состояния гонок
- •15.4. Блокировки чтения-записи
- •15.5. Атрибуты средств синхронизации потоков
- •15.5.1. Атрибуты взаимных исключений
- •Поведение взаимных исключений различных типов
- •15.5.2. Атрибуты условных переменных
- •15.5.3. Атрибуты блокировок чтения-записи
- •15.6. Выводы по главе 15
- •15.7. Упражнения по главе 15
- •Глава 16. Блокирование записей
- •16.1. Введение
- •16.2. Блокирование записей и файлов
- •16.3. Блокирование записей с помощью fcntl по стандарту Posix
- •16.4. Рекомендательная блокировка
- •16.5. Обязательная блокировка
- •16.6. Приоритет чтения и записи Выводы по главе 16
- •Упражнения по главе 16 Глава 17. System V ipc
- •17.1. Введение
- •17.2. Ключи типа key_t и функция ftok
- •17.3. Структура ipc_perm
- •17.4. Создание и открытие каналов ipc
- •17.5. Разрешения ipc
- •17.6. Программы ipcs и ipcrm
- •17.7. Ограничения ядра
- •17.8. Выводы по главе 17
- •17.9. Упражнения по главе 17
- •Глава 18. Очереди сообщений System V
- •18.1. Введение
- •18.2. Функция msgget
- •18.3. Функция msgsnd
- •18.4. Функция msgrcv
- •18.5. Функция msgctl
- •18.6. Пример программы клиент-сервер
- •18.7. Мультиплексирование сообщений
- •18.7.1. Пример: одна очередь на приложение
- •18.7.2. Пример: одна очередь для каждого клиента
- •18.8. Ограничения, накладываемые на очереди сообщений
- •18.9. Выводы по главе 18
- •18.10. Упражнения по главе 18
- •Глава 19. Семафоры System V
- •19.1. Введение
- •19.2. Функция semget
- •19.3. Функция semop
- •19.4. Функция semctl
- •19. . Ограничения семафоров System V
- •19. . Выводы по главе 19
- •19. . Упражнения по главе 19 Глава 20. Введение в разделяемую память
- •20.1. Введение
- •20.2. Функции mmap, munmap и msync
- •20.3. Увеличение счетчика в отображаемом в память файле
- •20.4. Неименованное отображение в память
- •20.5. Обращение к объектам, отображенным в память
- •20.6. Выводы по главе 20
- •20.7. Упражнения по главе 20
- •Глава 21. Разделяемая память System V
- •21.1. Введение
- •21.2. Функция shmget
- •21.3. Функция shmat
- •21.4. Функция shmdt
- •21.5. Функция shmctl
- •21.6. Ограничения, накладываемые на разделяемую память
- •21.7. Выводы по главе 21
- •21.8. Упражнения по главе 21
20.6. Выводы по главе 20
Разделяемая память представляет собой самую быстродействующую форму IPC, потому что данные из разделяемой области памяти доступны всем потокам и процессам, работающим с ней. Обычно для координации совместных действий потоков и процессов, использующих разделяемую память, требуется некоторая форма синхронизации.
В этой главе мы подробно рассмотрели свойства функции mmapи отображение обычных файлов в память, потому что это один из способов организации взаимодействия между родственными процессами. После отображения файла в память для обращения к нему больше не нужно использовать системные вызовыread,writeиlseek– вместо этого можно напрямую работать с ячейками памяти, относящимися к той области, указатель на которую возвращает функцияmmap. Замена явных операций с файлом на обращение к ячейкам памяти может упростить программу и в некоторых случаях увеличить быстродействие.
Если необходимо совместное использование области памяти после вызова fork, можно упростить решение этой задачи, используя один из способов неименованного отображения в память.
20.7. Упражнения по главе 20
20.1. Что произойдет с программой из листинга 19.4, если добавить еще один повтор циклаfor?
20.2. Измените программу влистинге 19.2, указавMAP_PRIVATEвместоMAP_SHARED. Проверьте, что результаты будут такими же, как и при выполнении программы излистинга 19.1. Что будет содержаться в файле, отображенном в память, по завершении работы программы?
Глава 21. Разделяемая память System V
21.1. Введение
Для каждого сегмента разделяемой памяти ядро хранит нижеследующую структуру, определенную в заголовочном файле <sys/shm.h>, основные поля которой суть следующие:
struct shmid_ds
{
struct ipc_perm shm_perm; /* разрешения чтения-записи */
size_t shm_segsz; /* размер сегмента в байтах */
pid_t shm_lpid; /* идентификатор последнего процесса, вызвавшего
функцию shmat() или shmdt() */
pid_t shm_cpid; /* идентификатор процесса-создателя */
shmatt_t shm_nattch; /* текущее количество подключений */
time_t shm_atime; /* время последнего подключения shmat() */
time_t shm_dtime; /* время последнего отключения shmdt() */
time_t shm_ctime; /* время последнего вызова shmctl(), изменившего
значение хотя бы одного из полей структуры */
};
Структура ipc_permбыла описана в разделе 16.3; она содержит разрешения доступа к сегменту разделяемой памяти.
21.2. Функция shmget
С помощью функции shmgetможно создать новый сегмент разделяемой памяти или открыть существующий сегмент:
#include <sys/shm.h>
int shmget (key_t key, size_t size, int oflag);
/* возвращает идентификатор сегмента разделяемой памяти в случае успешного завершения, -1 – в случае ошибки */
Возвращаемое целочисленное значение называется идентификатором сегмента разделяемой памяти. Оно используется тремя другими функциями shmXXX.
Аргумент keyможет содержать значение, возвращаемое функциейftok, или константуIPC_PRIVATE, как обсуждалось в разделе 16.2.
Аргумент sizeуказывает размер сегмента в байтах. При создании нового сегмента разделяемой памяти нужно указать ненулевой размер. Если производится обращение к существующему сегменту, аргументsizeдолжен быть нулевым.
Флаг oflagпредставляет собой комбинацию флагов доступа на чтение и запись из табл. 16.3. К ним могут быть добавлены с помощью логического сложения флагиIPC_CREATилиIPC_CREAT | IPC_EXCL, как уже говорилось в связи с рис. 16.2.
Новый сегмент инициализируется нулями.
Обратите внимание, что функция shmgetсоздает или открывает сегмент разделяемой памяти, но не дает вызвавшему процессу доступа к нему. Для подключения сегмента памяти предназначена функцияshmat, описанная в следующем разделе.