Unix ユーザー ID (UID) は通常 16 ビットまたは 32 ビットの符号なし整数であることは理解していますが、特定のシステム (シェル内) でそれを調べるにはどうすればよいですか?
答え1
のについては<limits.h>
、 (または OS X などではそれに含まれるファイルの 1 つsys/syslimits.h
)を調べる必要があります。#define
UID_MAX
最近のオペレーティング システム (Solaris 2.x、OS X、BSD、Linux、HP-UX 11i、AIX 6) のほとんどは最大 20 億 ( 2^31-2
) を処理できるため、私はそれを前提として、それができないあまり知られていないシステムのための回避策を作成します。
答え2
glibc はこれらすべてのシステム タイプの定義を提供します。
確認してもいい/usr/include/bits/typesizes.h
:
% grep UID_T /usr/include/bits/typesizes.h
#define __UID_T_TYPE __U32_TYPE
次に以下を調べます/usr/include/bits/types.h
:
% grep '#define __U32_TYPE' /usr/include/bits/types.h
#define __U32_TYPE unsigned int
これにより、C 型を見つけることができます。バイト単位のサイズが必要なので、最適なオプションは、次の仕様に従って typedef 名を解析することですtypes.h
。
We define __S<SIZE>_TYPE and __U<SIZE>_TYPE for the signed and unsigned
variants of each of the following integer types on this machine.
16 -- "natural" 16-bit type (always short)
32 -- "natural" 32-bit type (always int)
64 -- "natural" 64-bit type (long or long long)
LONG32 -- 32-bit type, traditionally long
QUAD -- 64-bit type, always long long
WORD -- natural type of __WORDSIZE bits (int or long)
LONGWORD -- type of __WORDSIZE bits, traditionally long
それで、ここにワンライナーがあります:
% grep '#define __UID_T_TYPE' /usr/include/bits/typesizes.h | cut -f 3 | sed -r 's/__([US])([^_]*)_.*/\1 \2/'
U 32
ここでU
は を意味しunsigned
( の場合もこれS
に該当しますsigned
)、32
はサイズです (上記のリストで調べてください。ほとんどの場合、 はすでにバイト単位のサイズであると想定できますが、スクリプトを完全に移植可能にしたい場合は、この値をオンにしたほうがよい場合がありますcase
)。
答え3
でこのリンク質問が行われ、回答者は試行錯誤の方法で、問題のシステムが signed long int を使用し、値を格納するために 31 ビットを残し、最大値が 2,147,483,647 であるかどうかを判断します。
# groupadd -g 42949672950 testgrp
# more /etc/group
testgrp:*:2147483647:
答え4
それは興味深い質問です。これを判定するための標準的で移植可能な方法があるとしたら驚きです。
手元に Linux ボックスはありませんが、id
FreeBSD 8.0 のコマンドはゼロに戻ります。
# id 4294967296
uid=0(root) gid=0(wheel) groups=0(wheel),5(operator)
これは未定義の動作だと確信していますが、ほとんどのバージョンでは、(16 ビット UID の場合)id
ゼロにラップするか、システム制限を超えるとエラーが発生すると思います。65'536
4'294'967'296