Scroll to navigation

ASSERT_PERROR(3) Руководство программиста Linux ASSERT_PERROR(3)

ИМЯ

assert_perror - проверяет errnum и прекращает выполнение программы

ОБЗОР

#define _GNU_SOURCE         /* Смотрите feature_test_macros(7) */
#include <assert.h>

void assert_perror(int errnum);

ОПИСАНИЕ

Если на момент последнего включения <assert.h> был определён макрос NDEBUG, то для макроса assert_perror() не создаётся никакого кода и, соответственно, он вообще ничего не делает. В противном случае, макрос assert_perror() выводит в стандартный поток ошибок сообщение об ошибке и прекращает работу программы вызовом abort(3), если значение errnum не равно нулю. В сообщении содержится имя файла, имя функции и номер строки вызова макроса, а также результат вызова strerror(errnum).

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

Ничего не возвращается.

СООТВЕТСТВИЕ СТАНДАРТАМ

Это расширение GNU.

ДЕФЕКТЫ

Целью макроса assert является оказание помощи программистам в поиске ошибок в программах — таких сбоев, которые не могут случиться, если только не была допущена ошибка в коде программы. Однако, с системными или библиотечными вызовами ситуация немного отличается, и возврат ошибки может произойти и, собственно, произойдёт и должен быть проверен, но не через assert, где проверка не получится, если определено NDEBUG, а правильным кодом обработки ошибок. Никогда не используйте этот макрос.

СМОТРИТЕ ТАКЖЕ

abort(3), assert(3), exit(3), strerror(3)

2002-08-25 GNU