sysconf − 動 作 中 に 設 定 情 報 を 取 得 す る
#include <unistd.h>
long sysconf(int name);
POSIX で は 、 ア プ リ ケ ー シ ョ ン が コ ン パ イ ル 時 や 実 行 時 に 、 特 定 の オ プ シ ョ ン が サ ポ ー ト さ れ て い る か や 、 設 定 可 能 な 特 定 の 定 数 や 制 限 が ど ん な 値 か を テ ス ト す る こ と が で き る 。 コ ン パ イ ル 時 に 行 う に は 、 <unistd.h> と <limits.h> の 両 方 も し く は 一 方 を イ ン ク ル ー ド し 、 特 定 の マ ク ロ の 値 を 確 認 す る 。 実 行 時 に は 、 こ こ で 説 明 す る 関 数 sysconf() を 使 っ て 数 値 を 問 い 合 わ せ る こ と が で き る 。 フ ァ イ ル が 存 在 す る フ ァ イ ル シ ス テ ム に 関 す る 数 値 は 、 fpathconf(3) と pathconf(3) を 使 っ て 確 認 で き る 。 文 字 列 の 値 は confstr(3) を 使 っ て 確 認 で き る 。 こ れ ら の 関 数 で 取 得 さ れ る 値 は 設 定 可 能 な シ ス テ ム 定 数 で あ る 。 こ れ ら は プ ロ セ ス の 生 存 期 間 の 間 は 変 化 し な い 。 オ プ シ ョ ン を 確 認 で き る よ う に 、 た い て い は <unistd.h> で 定 数 _POSIX_FOO が 定 義 さ れ て い る 。 定 義 さ れ て い な い と き は 、 実 行 時 に 問 い 合 わ せ を 行 う 必 要 が あ る 。 そ の 値 が −1 に 定 義 さ れ て い る と き は 、 そ の オ プ シ ョ ン は サ ポ ー ト さ れ て い な い 。 0 に 定 義 さ れ て い る と き は 、 関 連 す る 関 数 や ヘ ッ ダ フ ァ イ ル が 存 在 す る が 、 ど の 程 度 サ ポ ー ト さ れ て い る か は 実 行 時 に 確 認 し な け れ ば な ら な い 。 −1 で も 0 で も な い 値 に 定 義 さ れ て い る と き は 、 そ の オ プ シ ョ ン が サ ポ ー ト さ れ て い る 。 通 常 は 、 そ の オ プ シ ョ ン に つ い て 記 載 し た POSIX の 改 訂 年 月 を 示 す 値 に な っ て い る (例 え ば 200112L)。 glibc で は 1 が 設 定 さ れ て い る と 、 そ の オ プ シ ョ ン は サ ポ ー ト さ れ て い る が 、 POSIX の 改 訂 版 が ま だ 発 行 さ れ て い な い こ と を 示 す 。 sysconf() の 引 き 数 に は _SC_FOO を 指 定 す る 。 オ プ シ ョ ン の リ ス ト に つ い て は posixoptions(7) を 参 照 の こ と 。 変 数 や 制 限 を 確 認 で き る よ う に 、 た い て い は 、 <limits.h> で 定 数 _FOO が 、 <unistd.h> で _POSIX_FOO が 定 義 さ れ て い る 。 制 限 が 規 定 さ れ て い な い 場 合 は 定 数 は 定 義 さ れ な い 。 定 数 が 定 義 さ れ て い る と き に は 、 そ の 定 数 は 保 証 で き る 値 で あ り 、 実 際 に は も っ と 大 き な 値 が サ ポ ー ト さ れ て い る こ と も あ る 。 ア プ リ ケ ー シ ョ ン が シ ス テ ム 毎 に 変 化 す る 値 を 利 用 し た い 場 合 に は 、 sysconf() を 呼 び 出 す こ と で 実 現 で き る 。 sysconf() の 引 き 数 に は _SC_FOO を 指 定 す る 。
POSIX.1
変 数 変 数 名 、
そ の 値 を 取 得
す る の に 使 わ
れ る sysconf() の パ
ラ メ ー タ 名 、
簡 単 な 説 明 を
以 下 に 示 す 。
ま ず POSIX.1 互 換 の
変 数 を 示 す 。
ARG_MAX - _SC_ARG_MAX
exec(3) 関 数 群 の 引 き 数 の 最 大 長 。 _POSIX_ARG_MAX (4096) 未 満 で あ っ て は な ら な い 。
CHILD_MAX -
_SC_CHILD_MAX ユ ー ザ ID あ
た り の 同 時 に
存 在 で き る プ
ロ セ ス の 最 大
数 。 _POSIX_CHILD_MAX (25) 未
満 で あ っ て は
な ら な い 。
HOST_NAME_MAX - _SC_HOST_NAME_MAX
gethostname(2) で 返 さ れ る ホ ス ト 名 の 最 大 長 。 末 尾 の NULL バ イ ト は 長 さ に 含 ま れ な い 。 _POSIX_HOST_NAME_MAX (255) 未 満 で あ っ て は な ら な い 。
LOGIN_NAME_MAX -
_SC_LOGIN_NAME_MAX ロ グ イ
ン 名 の 長 さ の
最 大 値 。 末 尾
の NULL バ イ ト も 長
さ に 含 ま れ る
。 _POSIX_LOGIN_NAME_MAX (9) 未 満
で あ っ て は な
ら な い 。
clock ticks - _SC_CLK_TCK
1秒 あ た り の ク ロ ッ ク ・ テ ィ ッ ク 数 。 対 応 す る 変 数 は 廃 止 さ れ た 。 こ の 変 数 は 当 然 な が ら CLK_TCK と 呼 ば れ て い た 。 (注 意 : マ ク ロ CLOCKS_PER_SEC か ら は 情 報 は 得 ら れ な い : こ の 値 は 1000000 で な け れ ば な ら な い )
OPEN_MAX -
_SC_OPEN_MAX 一 つ の プ
ロ セ ス が 同 時
に オ ー プ ン で
き る フ ァ イ ル
数 の 上 限 。
_POSIX_OPEN_MAX (20) 未 満 で
あ っ て は な ら
な い 。
PAGESIZE - _SC_PAGESIZE バ イ
ト 単 位 で の ペ
ー ジ サ イ ズ 。 1
よ り 小 さ く な
っ て は な ら な
い 。 (こ の 代 わ
り に PAGE_SIZE を 使 う
シ ス テ ム も あ
る )
RE_DUP_MAX - _SC_RE_DUP_MAX
regexec(3) と regcomp(3) で 許 容 さ れ て い る BRE (Basic Regular Expression; 基 本 正 規 表 現 ) の 繰 り 返 し 出 現 回 数 の 最 大 値 。 _POSIX2_RE_DUP_MAX (255) 未 満 で あ っ て は な ら な い 。
STREAM_MAX -
_SC_STREAM_MAX 一 つ の プ
ロ セ ス が 同 時
に オ ー プ ン で
き る ス ト リ ー
ム 数 の 上 限 。
定 義 さ れ て い
た 場 合 に は 、
こ の 値 は 標 準 C
マ ク ロ の FOPEN_MAX
と 同 じ で あ る
。 _POSIX_STREAM_MAX (8) 未 満
で あ っ て は な
ら な い 。
SYMLOOP_MAX パ ス 名 の 解
決 時 に 現 れ て
も よ い シ ン ボ
リ ッ ク ・ リ ン
ク の 最 大 数 。
こ の 数 を 超 え
る と 、 パ ス 名
解 決 時 に ELOOP が
返 さ れ る 。
_POSIX_SYMLOOP_MAX (8) 未 満 で
あ っ て は な ら
な い 。
TTY_NAME_MAX - _SC_TTY_NAME_MAX 端 末
デ バ イ ス 名 の
最 大 長 。 長 さ
に は 末 尾 の NULL バ
イ ト も 含 ま れ
る 。 _POSIX_TTY_NAME_MAX (9) 未
満 で あ っ て は
な ら な い 。
TZNAME_MAX - _SC_TZNAME_MAX タ イ
ム ゾ ー ン 名 と
し て 使 え る バ
イ ト 数 の 最 大
値 。 _POSIX_TZNAME_MAX (6) 未
満 で あ っ て は
な ら な い 。
_POSIX_VERSION - _SC_VERSION
POSIX.1 標 準 が 承 認 さ れ た 年 月 。 YYYYMML と い う 書 式 で あ る 。 199009L と い う 値 は 、 1990年 9月 改 訂 で あ る こ と を 示 す 。
POSIX.2
変 数 次 に 、 POSIX.2
の 値 を 示 す 。
こ れ ら は 各 ユ
ー テ ィ リ テ ィ
に 対 す る 制 限
を 指 定 す る 。
BC_BASE_MAX - _SC_BC_BASE_MAX
bc(1) ユ ー テ ィ リ テ ィ で 許 容 さ れ る obase の 最 大 値 。
BC_DIM_MAX - _SC_BC_DIM_MAX
bc(1) で 許 容 さ れ る 一 つ の 配 列 中 の 要 素 数 の 最 大 値 。
BC_SCALE_MAX - _SC_BC_SCALE_MAX
bc(1) で 許 さ れ る scale の 最 大 値 。
BC_STRING_MAX - _SC_BC_STRING_MAX
bc(1) で 許 容 さ れ る 文 字 列 の 最 大 長 。
COLL_WEIGHTS_MAX -
_SC_COLL_WEIGHTS_MAX ロ ケ ー
ル 定 義 フ ァ イ
ル 中 の LC_COLLATE order キ
ー ワ ー ド の エ
ン ト リ に 割 り
当 て 可 能 な 重
み の 最 大 値 。
EXPR_NEST_MAX - _SC_EXPR_NEST_MAX
expr(1) に お い て 、 括 弧 で 入 れ 子 に で き る 式 の 最 大 数 。
LINE_MAX -
_SC_LINE_MAX ユ ー テ ィ
リ テ ィ の 入 力
行 の 最 大 長 。
標 準 入 力 だ け
で な く 、 フ ァ
イ ル か ら の 入
力 に も 適 用 さ
れ る 。 長 さ に
は 行 の 末 尾 の
改 行 文 字 も 含
ま れ る 。
RE_DUP_MAX - _SC_RE_DUP_MAX 正 規
表 現 で 区 間 表
記 (interval notation) \{m,n\} が
使 用 さ れ た と
き に 許 容 さ れ
る 繰 り 返 し 出
現 回 数 の 最 大
値 。
POSIX2_VERSION - _SC_2_VERSION
POSIX.2 標 準 の バ ー ジ ョ ン 。 YYYYMML と い う 書 式 で 表 記 さ れ る 。
POSIX2_C_DEV - _SC_2_C_DEV
POSIX.2 の C 言 語 開 発 機 能 が サ ポ ー ト さ れ て い る か を 示 す 。
POSIX2_FORT_DEV - _SC_2_FORT_DEV
POSIX.2 の FORTRAN 開 発 ユ ー テ ィ リ テ ィ が サ ポ ー ト さ れ て い る か を 示 す 。
POSIX2_FORT_RUN - _SC_2_FORT_RUN
POSIX.2 の FORTRAN ラ ン タ イ ム ユ ー テ ィ リ テ ィ が サ ポ ー ト さ れ て い る か を 示 す 。
_POSIX2_LOCALEDEF - _SC_2_LOCALEDEF
localedef(1) を 使 っ た 、 POSIX.2 の ロ ケ ー ル の 作 成 を サ ポ ー ト し て い る か を 示 す 。
POSIX2_SW_DEV - _SC_2_SW_DEV
POSIX.2 ソ フ ト ウ ェ ア 開 発 ユ ー テ ィ リ テ ィ オ プ シ ョ ン が サ ポ ー ト さ れ て い る か を 示 す 。 以 下 の 値 も 存 在 す る が 、 標 準 に は 含 ま れ て い な い 。
- _SC_PHYS_PAGES
物 理 メ モ リ の
ペ ー ジ 数 。 こ
の 値 と _SC_PAGE_SIZE 値
の 積 は 桁 溢 れ
す る 可 能 性 が
あ る の で 注 意
す る こ と 。
- _SC_AVPHYS_PAGES 現 在 利
用 可 能 な 物 理
メ モ リ の ペ ー
ジ 数 。
- _SC_NPROCESSORS_CONF 設 定 さ
れ た プ ロ セ ッ
サ 数 。
- _SC_NPROCESSORS_ONLN 現 在 オ
ン ラ イ ン の (利
用 可 能 な ) プ ロ
セ ッ サ 数 。
name が 不 正 な 場 合 、 −1 が 返 さ れ 、 errno に EINVAL が 設 定 さ れ る 。 そ れ 以 外 の 場 合 、 シ ス テ ム リ ソ ー ス の 値 が 返 り 値 と し て 返 さ れ 、 errno は 変 更 さ れ な い 。 問 い 合 わ せ が オ プ シ ョ ン に つ い て で あ れ ば 、 そ の オ プ シ ョ ン が 利 用 で き る と き は 正 の 値 が 返 さ れ 、 利 用 で き な い と き は −1 が 返 さ れ る 。 問 い 合 わ せ が 制 限 に つ い て 場 合 は 、 制 限 が 設 定 さ れ て い な い と き に −1 が 返 さ れ る 。
POSIX.1-2001.
ARG_MAX を 使 う の は 難 し い 、 な ぜ な ら 、 exec(3) の 引 き 数 領 域 (argument space) の う ち ど れ く ら い が ユ ー ザ の 環 境 変 数 に よ っ て 使 わ れ る か は 分 か ら な い か ら で あ る 。 い く つ か の 返 り 値 は と て も 大 き く な る だ ろ う 。 こ れ ら を 使 っ て メ モ リ の 割 り 当 て を 行 う の は 適 当 で は な い 。
bc(1), expr(1), getconf(1), locale(1), fpathconf(3), pathconf(3), posixoptions(7)