unpack
(PHP 4, PHP 5, PHP 7, PHP 8)
unpack — Entpackt die Daten einer binäre Zeichenkette
Beschreibung
$format
, string $string
, int $offset
= 0): array|false
Überträgt die Daten einer binäre Zeichenkette in ein Array unter
Berücksichtigung des Parameters format
.
Die entpackten Daten werden in einem assoziativen Array abgebildet. Hierzu müssen die verschiedenen Format-Codes benannt und mit "/" getrennt werden. Wenn ein sich wiederholendes Argument existiert, werden die Array-Schlüssel durchnummeriert, indem ihnen eine Zahl angehängt wird.
Änderungen wurden durchgeführt, um diese Funktion in Übereinstimmung mit Perl zu bringen:
- Der Code "a" erhält nun abschließende NULL Bytes.
- Der Code "A" entfernt nun alle abschließenden ASCII Whitespaces (Leerzeichen, Tabs, Zeilenvorschübe, Wagenrückläufe und NULL Bytes).
- Der Code "Z" wurde für mit NULL aufgefüllte Zeichenketten hinzugefügt, und entfernt abschließende NULL Bytes.
Parameter-Liste
-
format
-
Die Format-Codes werden unter pack() näher erläutert.
-
string
-
Die gepackten Daten.
-
offset
-
Der Offset, an dem das Entpacken beginnt.
Rückgabewerte
Gibt ein assoziatives Array zurück, das die entpackten Elemente als binäre
Zeichenkette enthält. Bei einem Fehler wird false
zurückgegeben.
Changelog
Version | Beschreibung |
---|---|
7.2.0 | float- und double-Typen unterstützen sowohl Big-Endian als auch Little-Endian. |
7.1.0 |
Der optionale offset wurde hinzugefügt.
|
Beispiele
Beispiel #1 unpack()-Beispiel
<?php
$binarydata = "\x04\x00\xa0\x00";
$array = unpack("cchars/nint", $binarydata);
print_r($array);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
Array ( [chars] => 4 [int] => 160 )
Beispiel #2 unpack()-Beispiel mit Wiederholer
<?php
$binarydata = "\x04\x00\xa0\x00";
$array = unpack("c2chars/nint", $binarydata);
print_r($array);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
Array ( [chars1] => 4 [chars2] => 0 [int] => 40960 )
Anmerkungen
Beachten Sie, dass PHP Integer-Werte intern mit Vorzeichen speichert. Wenn Sie einen großen vorzeichenlosen Longwert entpacken und er von der selben Größe ist, die PHP für dessen Speicherung verwendet, wird das Ergebnis ein negativer Wert sein (auch wenn Sie dieses als vorzeichenlos zu entpacken angegeben haben).
Wird ein Element nicht benannt, dann werden numerische Indizes beginnend
mit 1
verwendet. Es ist zu berücksichtigen, dass im
Falle mehrerer unbenannter Elemente ein Teil der Daten überschrieben wird,
da die Nummerierung für jedes Element wieder bei 1
beginnt.
Beispiel #3 unpack()-Beispiel mit unbenannten Schlüsseln
<?php
$binarydata = "\x32\x42\x00\xa0";
$array = unpack("c2/n", $binarydata);
var_dump($array);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
array(2) { [1]=> int(160) [2]=> int(66) }
Es ist zu beachten, dass der erste Wert vom Symbol c
mit dem Wert vom Symbol n
überschrieben wurde.