-->

UNIX: разработка сетевых приложений

На нашем литературном портале можно бесплатно читать книгу UNIX: разработка сетевых приложений, Стивенс Уильям Ричард-- . Жанр: ОС и Сети. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале bazaknig.info.
UNIX: разработка сетевых приложений
Название: UNIX: разработка сетевых приложений
Дата добавления: 16 январь 2020
Количество просмотров: 378
Читать онлайн

UNIX: разработка сетевых приложений читать книгу онлайн

UNIX: разработка сетевых приложений - читать бесплатно онлайн , автор Стивенс Уильям Ричард

Новое издание книги, посвященной созданию веб-серверов, клиент-серверных приложений или любого другого сетевого программного обеспечения в операционной системе UNIX, — классическое руководство по сетевым программным интерфейсам, в частности сокетам. Оно основано на трудах Уильяма Стивенса и полностью переработано и обновлено двумя ведущими экспертами по сетевому программированию. В книгу включено описание ключевых современных стандартов, реализаций и методов, она содержит большое количество иллюстрирующих примеров и может использоваться как учебник по программированию в сетях, так и в качестве справочника для опытных программистов.

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

Перейти на страницу:

 const struct strbuf *<i>dataptr</i>, int <i>flags</i>);

<i>Обе функции возвращают: неотрицательное значение в случае успешного выполнения (см. пояснения в тексте), -1 в случае ошибки</i>

Обе составляющие сообщения — и сами данные, и управляющая информация — описываются структурой

strbuf
:

struct strbuf {

 int  maxlen; /* максимальный размер буфера buf */

 int  len;    /* фактическое количество данных в buf */

 char *buf;   /* данные */

};

ПРИМЕЧАНИЕ

Обратите внимание на аналогию между структурами strbuf и netbuf. Имена элементов обеих структур одинаковы.

Однако обе длины в структуре netbuf относятся к типу данных unsigned int (целое без знака), тогда как обе длины в структуре srtbuf — к типу int (целое со знаком). Причина в том, что некоторые потоковые функции используют значение -1 элементов len и maxlen для указания на определенные специальные ситуации.

С помощью функции

putmsg
мы можем отправлять или данные, или управляющую информацию, или и то и другое вместе. Для указания на отсутствие управляющей информации мы можем или задать
ctlptr
как пустой указатель, или установить значение
ctlptr-&gt;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-&gt;len
, установленное в -1. Аналогично, если отсутствуют данные, указанием на это является значение -1 элемента
dataptr-&gt;len
.

Если функция

putmsg
выполнилась успешно, то она возвращает нулевое значение, а в случае ошибки возвращается значение -1. Но функция
getmsg
возвращает нулевое значение только в том случае, если вызывающему процессу было доставлено все сообщение целиком. Если буфер, предназначенный для приема управляющей информации, слишком мал, то возвращается значение
MORECTL
(о котором заранее известно, что оно является неотрицательным). Аналогично, если буфер для приема данных оказывается слишком мал, возвращается значение
MOREDATA
. Если же оба эти буфера оказываются слишком малы, то возвращается логическая сумма этих двух флагов.

31.4. Функции getpmsg и putpmsg

Когда с выпуском SVR4 к потоковым системам была добавлена поддержка различных полос приоритета, появились новые варианты функций

getmsg
и
putmsg
.

#include &lt;stropts.h&gt;

int getpmsg(int <i>fd</i>, struct strbuf *<i>ctlptr</i>,

 struct strbuf *<i>dataptr</i>, int *<i>bandp</i>, int *<i>flagsp</i>);

int putpmsg(int <i>fd</i>, const struct strbuf *<i>ctlptr</i>,

 const struct strbuf *<i>dataptr</i>, int <i>band</i>, int <i>flags</i>);

<i>Обе функции возвращают: неотрицательное значение в случае успешного выполнения, -1 в случае ошибки</i>

Аргумент

band
функции
putpmsg
должен иметь значение в пределах от 0 до 255 включительно. Если аргумент
flags
имеет значение
MSG_BAND
, то генерируется сообщение в соответствующей полосе приоритета. Присваивание аргументу
flags
значения
MSG_BAND
и задание полосы 0 эквивалентно вызову функции
putmsg
. Если значение аргумента
flags
равно
MSG_HIPRI
, то аргумент
band
должен быть равен нулю, и тогда генерируется сообщение с высоким приоритетом. (Обратите внимание на то, что этот флаг имеет название, отличающееся от названия
RS_HIPRI
, используемого в случае функции
putmsg
.)

Два целочисленных значения, на которые указывают аргументы

bandp
и
flagsp
функции
getpmsg
, являются аргументами типа «значение-результат». Целочисленное значение, на которое указывает аргумент
flagsp
функции
getpmsg
, может соответствовать
MSG_HIPRI
(для чтения сообщений с высоким приоритетом),
MSG_BAND
(для чтения сообщений из полосы приоритета, по меньшей мере равной целочисленному значению, на которое указывает аргумент
bandp
) или
MSG_ANY
(для чтения любых сообщений). По завершении функции целочисленное значение, на которое указывает аргумент
bandp
, указывает на полосу приоритета прочитанного сообщения, а целое число, на которое указывает аргумент
flagsp
, соответствует
MSG_HIPRI
(если было прочитано сообщение с высоким приоритетом) или MSG_BAND (если было прочитано иное сообщение).

Перейти на страницу:
Комментариев (0)
название