В справочной странице для системного вызова write (2) -
ssize_t write(int fd, const void *buf, size_t count);
сказано следующее:
Возвращаемое значение
В случае успеха количество байтов
записано возвращено (ноль указывает
ничего не было написано). При ошибке -1
возвращается, и errno
установлен
соответственно. Если счет равен нулю и
дескриптор файла относится к
обычный файл, 0 может быть возвращен или
ошибка может быть обнаружена. Для особого
файл, результаты не переносимы.
Я бы интерпретировал это как означающее, что возвращение 0 просто означает, что ничего не было написано по любой произвольной причине.
Однако Стивенс в UNP обрабатывает возвращаемое значение 0 как фатальную ошибку при работе с файловым дескриптором, который является TCP-сокетом (это оборачивается другой функцией, которая вызывает exit(1)
на коротком количество):
ssize_t /* Write "n" bytes to a descriptor. */
writen(int fd, const void *vptr, size_t n)
{
size_t nleft;
ssize_t nwritten;
const char *ptr;
ptr = vptr;
nleft = n;
while (nleft > 0) {
if ( (nwritten = write(fd, ptr, nleft)) <= 0) {
if (nwritten < 0 && errno == EINTR)
nwritten = 0; /* and call write() again */
else
return(-1); /* error */
}
nleft -= nwritten;
ptr += nwritten;
}
return(n);
}
Он рассматривает 0 как допустимое возвращаемое значение, только если errno
указывает, что запрос на запись был прерван процессом, получающим сигнал.
Почему?