Насколько велик (в битах) UID UIX?
Я понимаю, что пользовательские идентификаторы Unix (UID), как правило, представляют собой 16- или 32-разрядные целые числа без знака, но как я могу узнать это для любой системы (в оболочке)?
4 ответа
Вам нужно будет заглянуть в <limits.h>
(или один из файлов, который он включает, например, sys/syslimits.h
на OS X) для #define
из UID_MAX
,
Самые последние операционные системы (Solaris 2.x, OS X, BSD, Linux, HP-UX 11i, AIX 6) могут обрабатывать до двух миллиардов (2^31-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
включите это значение).
В этой ссылке задается вопрос, и респондент использует метод проб и ошибок, чтобы определить, что рассматриваемая система использует длинное целое со знаком, оставляя 31 бит для хранения значения, с максимальным значением 2 147 483 647.
# groupadd -g 42949672950 testgrp
# more /etc/group
testgrp:*:2147483647:
Это интересный вопрос. Я был бы удивлен, если бы был стандартный, портативный метод, чтобы определить это.
У меня нет удобной коробки с Linux, но id
команда во FreeBSD 8.0 возвращается к нулю:
# id 4294967296
uid=0(root) gid=0(wheel) groups=0(wheel),5(operator)
Я уверен, что это неопределенное поведение, но я держу пари, что большинство версий id
будет либо обернуть к нулю с 65'536
(если 16-битный UID) и 4'294'967'296
или ошибка, если вы вышли за пределы системы.