Home > Article > Backend Development > Detailed explanation and examples of php pack() function
pack and unpack are really not easy to see in ordinary programs, but if you have used PHP to generate excel a long time ago, you will know it. The header of his excel is just packed. I recently used this thing again when trying to interact with C, so I had to take a look again. In fact, it was C who required me to have a Baotou. . . In fact, pure strings are also good. Why do you have to get a bun? Really confused...
There are introductions to pack and unpack in the manual, but they are all in English. . .
Back to the topic, this article introduces how to use the pack and unpack methods. The official PHP manual has too few examples to make it easy to understand, especially the use of formatting parameters.
Chinese explanation of the parameters of the excerpt:
pack/unpack template character character meaning
b A bit string, with bits in each byte The order is in ascending order
C An unsigned char (8-bit integer) value; about Unicode, see U
h A hexadecimal string, low-order four bits first
H A hexadecimal string, high-order four digits first
i a signed integer value, native format
I an unsigned integer value, native format
l a signed long, always 32 bits
L an unsigned long, always 32 bits
n a 16-bit Short integer, "network" byte order (big endian)
N A 32-bit short integer, "network" byte order (big endian)
p A pointer to a null-terminated string
P A pointer to a fixed-length Pointer to string
q A signed quad (64-bit integer) value
Q An unsigned quad (64-bit integer) value
s A signed short integer value, always 16 bits
S An unsigned short integer Value, always 16 bits,
The byte order is related to the machine chip
u An unencoded string
U A Unicode character number
v A 16-bit short integer in "VAX" byte order (little end first)
V A 32-bit short integer in "VAX" byte order (little endian)
w A BER-compressed integer
x A null byte (one byte forward is ignored)
X Back up a byte
Z A Null-terminated (and null-padded) byte strings @ Pad absolute positions with null bytes string pack ( string $format [, mixed $args [, mixed $...]] )
Some rules:
1. Each letter can be followed by a number, which means count. If count is a *, it means everything else.
2. If you provide fewer parameters than $format requires, pack assumes that all missing values are null. If you provide more parameters than $format requires, the extra parameters are ignored.
It will be easier to understand using examples below:
PHP code