Где определяется PATH_MAX в Linux? - PullRequest
96 голосов
/ 26 февраля 2012

Какой заголовочный файл я должен вызывать с помощью #include, чтобы можно было использовать PATH_MAX в качестве целочисленного значения для определения размера строки?

Я хочу иметь возможность объявить:

char *current_path[PATH_MAX];

Но когда я это делаю, мой компилятор (Clang / LLVM в Linux) выдает следующую ошибку:

recursive_find6.c:29:20: error: use of undeclared identifier 'PATH_MAX'
char *current_path[PATH_MAX];
                   ^

Я пытался выполнить поиск в Google, но все равно не повезло.

#include <limits.h> НЕ устраняет проблему / ошибку.

Верно ли и то, что значение PATH_MAX является целым числом?

Ответы [ 4 ]

123 голосов
/ 26 февраля 2012

Это в linux/limits.h.
#define PATH_MAX 4096 /* # chars in a path name including nul */

#include <linux/limits.h>

char current_path[PATH_MAX];

PATH_MAX имеет некоторые недостатки, как упомянуто в этом блоге (спасибо paulsm4)

12 голосов
/ 20 ноября 2012

Имейте в виду, что до сих пор неясно, определяет ли PATH_MAX максимальную длину с завершающим нулевым байтом или без него. Это может быть один или другой в разных операционных системах. Если вы не можете или не хотите проверять, в каком случае это происходит во время компиляции, безопаснее установить искусственный предел в PATH_MAX - 1. Береженого Бог бережет. (Очевидно, вам все еще нужно зарезервировать как минимум PATH_MAX байтов памяти для буферизации строки.)

2 голосов
/ 11 июня 2017

Это хороший вопрос. Я занимаюсь простым программированием на C и столкнулся с этой проблемой. На вашем конкретном Linux / Unix в каталоге / usr / include находятся все файлы заголовков вашей системы.

find . -name "*.h" | xargs grep PATH_MAX 

Вы должны увидеть несколько заголовков, определяющих PATH_MAX. И вы можете видеть, что это значение определяется по-разному в разных местах. Вот список из моей Ubuntu (я также вручную удалил несколько ложных срабатываний из программы grep).

./x86_64-linux-gnu/bits/posix1_lim.h:#define _POSIX_PATH_MAX      256
./X11/InitialI.h:#ifndef PATH_MAX
./X11/InitialI.h:#define PATH_MAX 512
./X11/InitialI.h:#ifndef PATH_MAX
./X11/InitialI.h:#define PATH_MAX MAXPATHLEN
./X11/InitialI.h:#define PATH_MAX 1024
./X11/Xos.h:#  define PATH_MAX 4096
./X11/Xwindows.h:#if defined(WIN32) && (!defined(PATH_MAX) || PATH_MAX < 1024)
./X11/Xwindows.h:# undef PATH_MAX
./X11/Xwindows.h:# define PATH_MAX 1024
./X11/Xosdefs.h:#  ifndef PATH_MAX
./X11/Xosdefs.h:#   define PATH_MAX 4096
./X11/Xosdefs.h:#  ifndef PATH_MAX
./X11/Xosdefs.h:#   define PATH_MAX 1024
./X11/extensions/XKBsrv.h:#define   PATH_MAX MAXPATHLEN
./X11/extensions/XKBsrv.h:#define   PATH_MAX 1024
./python2.7/osdefs.h:#ifndef PATH_MAX
./python2.7/osdefs.h:#define PATH_MAX MAXPATHLEN
./python2.7/osdefs.h:#if defined(PATH_MAX) && PATH_MAX > 1024
./python2.7/osdefs.h:#define MAXPATHLEN PATH_MAX
./linux/limits.h:#define PATH_MAX        4096   /* # chars in a path name including nul */
./linux/btrfs.h:#define BTRFS_INO_LOOKUP_PATH_MAX 4080
./linux/un.h:#define UNIX_PATH_MAX  108

Похоже, что /linux/limits.h имеет наибольшее определенное число. Я действительно беспокоюсь о переносимости этого файла. Поэтому, чтобы быть в безопасности, вы можете просто определить этот MACRO под другим именем, например, PATHLEN (4080 достаточно для большинства практических ситуаций). Если это для большого пакета программ, у вас также есть контроль. Это моё мнение.

0 голосов
/ 30 мая 2019

Портативный способ сделать это:

#define _POSIX_C_SOURCE 1
#include <limits.h>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...