pack

(PHP 4, PHP 5, PHP 7, PHP 8)

packУпаковывает данные в двоичную строку

Описание

pack(string$format, mixed...$values): string

Функция упаковывает заданные аргументы в двоичную строку в соответствии с форматом в параметре format.

Идею функции заимствовали из языка программирования Perl, и коды форматирования работают так же, как они делают это в Perl. Однако части кодов форматирования нет, например, кода формата Perl «u».

Обратите внимание, что различия между знаковыми и беззнаковыми значениями влияют только на функцию unpack(), тогда как функция pack() даёт одинаковый результат для знаковых и беззнаковых кодов формата.

Список параметров

format

Строка format состоит из кодов формата, за которыми идёт необязательный аргумент повторителя. Значение аргумента повторителя указывают как целое число или как символ * для повторения до конца входных данных. Для кодов a, A, h, H число повторений указывает, сколько символов одного аргумента данных возьмёт функция, для кода @ — абсолютную позицию, в которую функция поместит следующие данные. Для остальных кодов форматирования число повторений указывает, сколько аргументов данных функция обработает и упакует в результирующую двоичную строку.

Доступные форматы:

Символы формата функции pack()
КодОписание
aСтрока (string) с NUL-дополнением
AСтрока (string) со SPACE-дополнением
hШестнадцатеричная строка (string), вначале младший полубайт
HШестнадцатеричная строка (string), вначале старший полубайт
cЗнаковый char
CБеззнаковый char
sЗнаковый short (всегда 16 битов, машинный порядок байтов)
SБеззнаковый short (всегда 16 битов, машинный порядок байтов)
nБеззнаковый short (всегда 16 битов, порядок байтов от старшего к младшему)
vБеззнаковый short (всегда 16 битов, порядок байтов от младшего к старшему)
iЗнаковый integer (машинно-зависимые размер и порядок байтов)
IБеззнаковый integer (машинно-зависимые размер и порядок байтов)
lЗнаковый long (всегда 32 бита, машинный порядок байтов)
LБеззнаковый long (всегда 32 бита, машинный порядок байтов)
NБеззнаковый long (всегда 32 бита, порядок байтов от старшего к младшему)
VБеззнаковый long (всегда 32 бита, порядок байтов от младшего к старшему)
qЗнаковый long long (всегда 64 бита, машинный порядок байтов)
QБеззнаковый long long (всегда 64 бита, машинный порядок байтов)
JБеззнаковый long long (всегда 64 бита, порядок байтов от старшего к младшему)
PБеззнаковый long long (всегда 64 бита, порядок байтов от младшего к старшему)
fЧисло с плавающей точкой float (машинно-зависимые размер и представление)
gЧисло с плавающей точкой float (машинно-зависимый размер, порядок байтов от младшего к старшему)
GЧисло с плавающей точкой float (машинно-зависимый размер, порядок байтов от старшего к младшему)
dЧисло double (машинно-зависимые размер и представление)
eЧисло double (машинно-зависимый размер, порядок байтов от младшего к старшему)
EЧисло double (машинно-зависимый размер, порядок байтов от старшего к младшему)
xNUL-байт
XРезервирование одного байта
ZСтрока (string) с NUL-дополнением
@NUL-заполнение до абсолютной позиции
values

Возвращаемые значения

Функция возвращает двоичную строку, которая содержит данные.

Список изменений

ВерсияОписание
8.0.0 Функция больше не возвращает false, если возникла ошибка.
7.2.0 Типы float и double поддерживают как прямой, так и обратный порядок байтов.
7.0.15,7.1.1 Добавили коды e, E, g и G для поддержки порядка байтов для типов float и double.

Примеры

Пример #1 Пример использования функции pack()

<?php

$binarydata
= pack("nvc*", 0x1234, 0x5678, 65, 66);

?>

Длина результирующей двоичной строки будет составлять 6 байтов, и строка будет содержать последовательность байтов: 0x12, 0x34, 0x78, 0x56, 0x41, 0x42.

Примечания

Предостережение

Обратите внимание, что внутренне PHP хранит значения с типом int как знаковые значения машинно-зависимого размера (тип long в языке программирования C). Целочисленные литералы и операции, которые возвращают числа за пределами типа int, будут храниться как float. При упаковке чисел с плавающей точкой как целых чисел числа с плавающей точкой сначала приводятся к целочисленному типу. Поэтому результат или будет совпадать с заданной структурой байтов, или нет.

Нагляднее остальных это показывает пример с упаковкой беззнаковых чисел, которые можно было бы представить типом int, если бы этот тип был беззнаковым. В системах, в которых размер int составляет 32 бита, приведение обычно даёт ту же структуру байтов, как если бы тип int был беззнаковым (хотя, это зависит от определяемых реализацией преобразований по правилам стандарта языка С беззнаковых чисел в числа со знаком). В системах, в которых размер типа int составляет 64 бита, у типа float, скорее всего, нет мантиссы необходимого размера, чтобы удерживать значение без потери точности. Если в этих системах также есть собственный 64-разрядный тип C int (в большей части UNIX-систем такого типа нет), то единственный способ использовать формат упаковки I в верхнем диапазоне — создать отрицательные значения с типом int с тем же байтовым представлением, что и у беззнакового значения, которое требуется получить.

Смотрите также

  • unpack() - Распаковывает данные из бинарной строки
To Top