Назад | Перейти на главную страницу

Насколько велик (в битах) UID Unix?

Я понимаю, что идентификаторы пользователей unix (UID) обычно представляют собой 16- или 32-битные целые числа без знака, но как я могу узнать об этой системе (в оболочке)?

Вам нужно будет заглянуть <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 бит для хранения значения с максимальным значением 2147483647.

# 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 или ошибка, если вы вышли за пределы системы.