Книга: UNIX: разработка сетевых приложений
31.3. Функции getmsg и putmsg
31.3. Функции getmsg и putmsg
Данные, передаваемые в обоих направлениях по потоку, состоят из сообщений, а каждое сообщение содержит данные, управляющую информацию или и то и другое. Если мы используем функции read
или write
, то мы можем передавать только данные. Для того чтобы процесс мог записывать и считывать как данные, так и управляющую информацию, необходимо добавить две новые функции.
#include <stropts.h>
int getmsg(int fd, struct strbuf *ctlptr, struct strbuf *dataptr, int *flagsp);
int putmsg(int fd, const struct strbuf *ctlptr,
const struct strbuf *dataptr, int flags);
Обе функции возвращают: неотрицательное значение в случае успешного выполнения (см. пояснения в тексте), -1 в случае ошибки
Обе составляющие сообщения — и сами данные, и управляющая информация — описываются структурой strbuf
:
struct strbuf {
int maxlen; /* максимальный размер буфера buf */
int len; /* фактическое количество данных в buf */
char *buf; /* данные */
};
ПРИМЕЧАНИЕ
Обратите внимание на аналогию между структурами strbuf и netbuf. Имена элементов обеих структур одинаковы.
Однако обе длины в структуре netbuf относятся к типу данных unsigned int (целое без знака), тогда как обе длины в структуре srtbuf — к типу int (целое со знаком). Причина в том, что некоторые потоковые функции используют значение -1 элементов len и maxlen для указания на определенные специальные ситуации.
С помощью функции putmsg
мы можем отправлять или данные, или управляющую информацию, или и то и другое вместе. Для указания на отсутствие управляющей информации мы можем или задать ctlptr
как пустой указатель, или установить значение ctlptr->len
равным -1. Этот же способ используется для указания на отсутствие данных.
При отсутствии управляющей информации функцией putmsg
генерируется сообщение типа M_DATA
(см. табл. 31.1), в противном случае генерируется сообщение типа M_PROTO
либо M_PCPROTO
в зависимости от значения аргумента flags
. Этот аргумент функции putmsg
имеет нулевое значение для обычных сообщений, а для сообщений с высоким приоритетом его значение равно RS_HIPRI
.
Последний аргумент функции getmsg
имеет тип «значение-результат». Если при вызове функции целочисленное значение, на которое указывает аргумент flagsp
, — это 0, то возвращается первое сообщение из потока (которое может быть как обычным, так и имеющим высокий приоритет). Если при вызове функции целочисленное значение соответствует RS_HIPRI
, то функция будет ждать появления в головном модуле потока сообщения с высоким приоритетом. В обоих случаях в зависимости от типа возвращенного сообщения значение, на которое указывает аргумент flagsp
, будет либо 0, либо RS_HIPRI
.
Предположим, что мы передаем функции getmsg
непустые указатели ctlptr
и dataptr
. Тогда указанием на отсутствие управляющей информации (возвращается сообщение типа M_DATA
) является значение ctlptr->len
, установленное в -1. Аналогично, если отсутствуют данные, указанием на это является значение -1 элемента dataptr->len
.
Если функция putmsg
выполнилась успешно, то она возвращает нулевое значение, а в случае ошибки возвращается значение -1. Но функция getmsg
возвращает нулевое значение только в том случае, если вызывающему процессу было доставлено все сообщение целиком. Если буфер, предназначенный для приема управляющей информации, слишком мал, то возвращается значение MORECTL
(о котором заранее известно, что оно является неотрицательным). Аналогично, если буфер для приема данных оказывается слишком мал, возвращается значение MOREDATA
. Если же оба эти буфера оказываются слишком малы, то возвращается логическая сумма этих двух флагов.
- 31.4. Функции getpmsg и putpmsg
- Аргументы функции в Python
- 3. Функции
- Новые функции API для работы с Blob и массивами
- Математические функции
- Размытые функции
- 7.3. Финансовые функции
- 4.3. Логические функции и таблицы истинности
- B1.7. Функции обработки ошибок
- 9.1.4.2. Функции-оболочки: execl() и др.
- 11.5. Функции getservbyname и getservbyport
- Функции dup(2) и dup2(2)