Читать книгу 📗 "Основы программирования в Linux - Мэтью Нейл"
shmctl
Функции управления совместно используемой памятью (к счастью) гораздо проще аналогичных, но более сложных функций для семафоров:
<b>int shmctl(int shm_id, int command, struct shmid_ds *buf);</b>У структуры типа
shmid_ds<b>struct shmid_ds {</b><b> uid_t shm_perm.uid;</b><b> uid_t shm_perm.gid;</b><b> mode_t shm_perm.mode;</b><b>}</b>Первый параметр
shm_idshmgetВторой параметр
commandТаблица 14.2
| Значение | Описание |
|---|---|
IPC_STAT | Задаёт данные в структуре shmid_ds |
IPC_SET | Устанавливает значения, связанные с совместно используемой памятью в соответствии с данными из структуры типа shmid_ds |
IPC_RMID | Удаляет сегмент совместно используемой памяти |
Третий параметр
bufВ случае успеха возвращает 0, в случае ошибки — -1. В стандарте X/Open не описано, что произойдет, если вы попытаетесь удалить присоединенный к процессу сегмент совместно используемой памяти. Обычно присоединенный, но удаленный сегмент совместно используемой памяти продолжает функционировать до тех пор, пока не будет отсоединен от последнего процесса. Но поскольку это поведение не задано в стандарте, на него лучше не рассчитывать.
Выполните упражнение 14.2.
После знакомства с функциями совместно используемой памяти можно написать программу для их использования. В данном упражнении вы напишите пару программ: shm1.c и shm2.c. Первая (потребитель) создаст сегмент разделяемой памяти и затем отобразит любые данные, записанные в него. Вторая (поставщик) присоединит существующий сегмент совместно используемой памяти и позволит вам ввести данные в этот сегмент.
1. Сначала создайте общий заголовочный файл для описания совместно используемой памяти, которую вы хотите предоставить. Назовите его shm_com.h.
#define TEXT_SZ 2048struct shared_use_st { int written_by_you; char some_text[TEXT_SZ];};В файле определена структура, которая будет применяться в обеих программах: потребителе и поставщике. Вы используете флаг
written_by_youint2. Первая программа shm1.c — потребитель. После заголовочных файлов создается сегмент совместно используемой памяти (размер равен вашей структуре, описывающей совместно используемую память) с помощью вызова
shmgetIPC_CREAT#include <unistd.h>#include <stdlib.h>#include <stdio.h>#include <string.h>#include <sys/shm.h>#include "shm_com.h"int main() { int running = 1; void *shared_memory = (void *)0; struct shared_use_st *shared_stuff; int shmid; srand((unsigned int)getpid()); shmid = shmget((key_t)1234, sizeof(struct shared_use_st), 0666 | IPC_CREAT); if (shmid == -1) { fprintf(stderr, "shmget failedn"); exit(EXIT_FAILURE); }3. Теперь вы делаете совместно используемую память доступной программе.
shared_memory = shmat(shmid, (void *)0, 0); if (shared memory == (void *)-1) { fprintf(stderr, "shmat failedn"); exit(EXIT_FAILURE); } printf("Memory attached at %Xn", (int)shared_memory);4. В следующем фрагменте программы сегмент
shared_memoryshared_stuffsome_textendsome_textsleep shared_stuff = (struct shared_use_st *)shared_memory; shared_stuff->written_by_you = 0; while (running) { if (shared_stuff->written_by_you) { printf("You wrote: %s", shared_stuff->some_text); sleep(rand() % 4); /* Заставляет другой процесс ждать нас! */ shared_stuff->written_by_you = 0; if (strncmp(shared_stuff->some_text, "end", 3) == 0) { running = 0; }