UNIX: разработка сетевых приложений
UNIX: разработка сетевых приложений читать книгу онлайн
Новое издание книги, посвященной созданию веб-серверов, клиент-серверных приложений или любого другого сетевого программного обеспечения в операционной системе UNIX, — классическое руководство по сетевым программным интерфейсам, в частности сокетам. Оно основано на трудах Уильяма Стивенса и полностью переработано и обновлено двумя ведущими экспертами по сетевому программированию. В книгу включено описание ключевых современных стандартов, реализаций и методов, она содержит большое количество иллюстрирующих примеров и может использоваться как учебник по программированию в сетях, так и в качестве справочника для опытных программистов.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала
2 #include <stdarg.h> /* заголовочный файл ANSI С */ 3 #include <syslog.h> /* для syslog() */ 4 int daemon_proc; /* устанавливается в ненулевое значение с помощью daemon_init() */ 5 static void err_doit(int, int, const char*, va_list); 6 /* Нефатальная ошибка, связанная с системным вызовом. 7 Выводим сообщение и возвращаем управление */ 8 void 9 err_ret(const char *fmt , ...)10 {11 va_list ap;12 va_start(ap, fmt);13 err_doit(1, LOG_INFO, fmt, ap);14 va_end(ap);15 return;16 }17 /* Фатальная ошибка, связанная с системным вызовом.18 Выводим сообщение и завершаем работу */19 void20 err_sys(const char *fmt)21 {22 va_list ap;23 va_start(ap, fmt);24 err_doit(1, LOG_ERR, fmt, ap);25 va_end(ap);26 exit(1);27 }28 /* Фатальная ошибка, связанная с системным вызовом.29 Выводим сообщение, сохраняем дамп памяти процесса и заканчиваем работу */30 void31 err_dump(const char *fmt, ... )32 {33 va_list ар;34 va_start(ap, fmt);35 err_doit(1, LOG_ERR, fmt, ap);36 va_end(ap);37 abort(); /* сохраняем дамп памяти и заканчиваем работу */38 exit(1);39 }40 /* Нефатальная ошибка, не относящаяся к системному вызову.41 Выводим сообщение и возвращаем управление */42 void43 err_msg(const char *fmt , ...)44 {45 va_list ap;46 va_start(ap, fmt);47 err_doit(0, LOG_INFO, fmt, ap);48 va_end(ap);49 return;50 }51 /* Фатальная ошибка, не относящаяся к системному вызову.52 Выводим сообщение и заканчиваем работу. */53 void54 err_quit(const char *fmt, ...)55 {56 va_list ap;57 va_start(ap, fmt);58 err_doit(0, LOG_ERR, fmt, ap);59 va_end(ap);60 exit(1);61 }62 /* Выводим сообщение и возвращаем управление.63 Вызывающий процесс задает "errnoflag" и "level" */64 static void65 err_doit(int errnoflag, int level, const char *fmt, va_list ap)66 {67 int errno_save, n;68 char buf[MAXLINE + 1];69 errno_save = errno; /* значение может понадобиться вызвавшему процессу */70 #ifdef HAVE_VSNPRINTF71 vsnprintf(buf, MAXLINE, fmt, ap); /* защищенный вариант */72 #else73 vsprintf(buf, fmt, ap); /* незащищенный вариант */74 #endif75 n = strlen(buf);76 if (errnoflag)77 snprintf(buf + n, MAXLINE - n, ": %s", strerror(errno_save));78 strcat(buf, "n");79 if (daemon_proc) {80 syslog(level, buf);81 } else {82 fflush(stdout); /* если stdout и stderr совпадают */83 fputs(buf, stderr);84 fflush(stderr);85 }86 return;87 }Приложение Д
Решения некоторых упражнений
Глава 1
1.3. В операционной системе Solaris получаем:
solaris % <b>daytimetcpcli 127.0.0.1</b>socket error: Protocol not supportedДля получения дополнительной информации об этой ошибке сначала используем программу
grepProtocol not supported<sys/errno.h>
