• В NAME_MAX не учитывается завершающий нулевой байт, в то время как в PATH_MAX он учитывается. Это противоречие исправляет ранее допущенную непоследовательность в стандарте POSIX.1, когда было непонятно, учитывается ли завершающий нулевой байт в PATH_MAX. Определение константы PATH_MAX как учитывающей завершающий нулевой байт означает, что приложения, выделяющие лишь указанное в PATH_MAX количество байтов для путевого имени, будут по-прежнему соответствовать стандарту.
Для получения ограничений и возможностей конкретной реализации UNIX из оболочки можно использовать команду getconf. Основной для этой команды является такая форма:
$ getconf
Аргумент variable-name идентифицирует требуемое ограничение и является одним из стандартных имен ограничений, указанных в SUSV3, например ARG_MAX или NAME_MAX. Когда ограничение имеет отношение к путевому имени, то в качестве второго аргумента в команде нужно указывать путевое имя (pathname) (см. второй пример ниже).
$ getconf ARG_MAX
131072
$ getconf NAME_MAX /boot
255
11.2. Извлечение в ходе выполнения программы значений ограничений (и возможностей) системы
Функция sysconf() позволяет приложению получить значения системных ограничений в ходе выполнения программы.
#include
long sysconf
(intВозвращает значение ограничения, указанного в аргументе name, при успешном завершении или –1, если ограничение не определено или же если произошла ошибка
Аргумент name является одной из констант вида _SC_*, определенных в файле
Если ограничение не может быть определено, функция sysconf() выдает –1. Она также может возвратить –1, если случится ошибка. (Единственной указываемой ошибкой является EINVAL, что означает недопустимость имени.) Чтобы отличить неопределенное ограничение от ошибки, нужно установить для errno перед вызовом значение 0. Если вызов возвратит –1 и после вызова для errno будет установлено значение, значит, произошла ошибка.
Значения ограничений, возвращенные sysconf() (а также pathconf() и fpathconf()), всегда относятся к (длинному) целочисленному типу данных (long). В пояснительном тексте для sysconf() в SUSv3 отмечается, что в качестве возможных возвращаемых значений рассматривались строки, но они были отвергнуты из-за сложности реализации и использования.
В листинге 11.1 показывается пример использования функции sysconf() для вывода различных ограничений системы. Запуск этой программы в одной из систем Linux 2.6.31/x86-32 приводит к выдаче следующей информации:
$ ./t_sysconf
_SC_ARG_MAX: 2097152
_SC_LOGIN_NAME_MAX: 256
_SC_OPEN_MAX: 1024
_SC_NGROUPS_MAX: 65536
_SC_PAGESIZE: 4096
_SC_RTSIG_MAX: 32
Листинг 11.1. Использование sysconf()
syslim/t_sysconf.c
#include "tlpi_hdr.h"
static void /* Выводит 'msg' плюс значение sysconf() для 'name' */
sysconfPrint(const char *msg, int name)
{
long lim;
errno = 0;
lim = sysconf(name);
if (lim!= -1) { /* Вызов прошел успешно, ограничение определено */
printf("%s %ld\n", msg, lim);
} else {
if (errno == 0)
/* Вызов прошел успешно, ограничение не определено */
printf("%s (indeterminate)\n", msg);
else /* Вызов не удался */
errExit("sysconf %s", msg);
}
}
int
main(int argc, char *argv[])
{
sysconfPrint("_SC_ARG_MAX: ", _SC_ARG_MAX);
sysconfPrint("_SC_LOGIN_NAME_MAX: ", _SC_LOGIN_NAME_MAX);
sysconfPrint("_SC_OPEN_MAX: ", _SC_OPEN_MAX);
sysconfPrint("_SC_NGROUPS_MAX: ", _SC_NGROUPS_MAX);
sysconfPrint("_SC_PAGESIZE: ", _SC_PAGESIZE);
sysconfPrint("_SC_RTSIG_MAX: ", _SC_RTSIG_MAX);
exit(EXIT_SUCCESS);
}
syslim/t_sysconf.c
В SUSv3 требуется, чтобы значение, возвращенное функцией sysconf() для конкретного ограничения, было постоянным на всем протяжении жизненного цикла вызывающего процесса. Например, можно предполагать, что значение, возвращаемое для _SC_PAGESIZE, не будет изменяться, пока продолжается работа процесса.