Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Erläuterung der Verwendung von Pack- und Unpack-Funktionen in PHP

Detaillierte Erläuterung der Verwendung von Pack- und Unpack-Funktionen in PHP

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼nach vorne
2020-01-02 17:52:065054Durchsuche

Detaillierte Erläuterung der Verwendung von Pack- und Unpack-Funktionen in PHP

Es gibt zwei Funktionen zum Packen und Entpacken in PHP. Viele PHPer haben sie noch nie in tatsächlichen Projekten verwendet und wissen nicht einmal, wofür diese beiden Methoden verwendet werden. In diesem Artikel erfahren Sie, wofür sie verwendet werden.

pack

string pack ( string $format [, mixed $args [, mixed $... ]] )

Diese Funktion wird verwendet, um die entsprechenden Parameter ($args) in einen Binärstring zu packen.

Der erste Parameter, $format, hat die folgenden Optionen (es gibt viele optionale Parameter und einige häufig verwendete werden später erklärt):

Detaillierte Erläuterung der Verwendung von Pack- und Unpack-Funktionen in PHP

Detaillierte Erläuterung der Verwendung von Pack- und Unpack-Funktionen in PHP

Nachdem ich mir so viele Parameter angesehen hatte, war ich zum ersten Mal wirklich verwirrt. Die meisten Anweisungen sind leicht zu verstehen, aber wie ist die Bytereihenfolge von Host, Big Endian, Little Endian usw .? Der folgende Inhalt ist relativ langweilig, aber er muss verstanden werden, also bleiben Sie dabei.

Was ist Bytereihenfolge?

ist die Reihenfolge der Bytes, um es ganz klar auszudrücken: Es ist die Reihenfolge, in der Multibyte-Daten gespeichert werden (ein Byte erfordert offensichtlich keine Reihenfolge).

Zum Beispiel sind die binären Darstellungen von A und B 0100 0001 bzw. 0100 0010. Für die Speicherung der Zeichenfolge AB können wir entweder 0100 0001 0100 0010 oder 0100 0010 0100 0001 verwenden. Diese Reihenfolge ist die sogenannte Byte-Reihenfolge.

High/Low-Byte

Beispiel: Zeichenfolge AB, links hoch und rechts niedrig (unsere normale Lesereihenfolge), A ist das Hoch Wortabschnitt, B ist das Low-Byte

High/Low-Adresse

Angenommen, 0x123456 wird in der Reihenfolge von hoch nach niedrig gespeichert, der Speicher wird wie folgt gespeichert:

Hohe Adresse-> Niedrige Adresse

12 -> 34 -> 56

Big Endian ( Netzwerkbyte Reihenfolge)

Big Endian bedeutet, dass die höherwertigen Bytes am unteren Adressende des Speichers und die niederwertigen Bytes am oberen Adressende platziert werden. Bei der Netzwerkübertragung (z. B. TCP/IP) wird das untere Adressende (hohes Byte) am Anfang des Streams platziert. Für eine 2-Byte-Zeichenfolge (AB) lautet die Übertragungsreihenfolge: A (0-7 Bit). B (8-15 Bit).

Dann ist die Little-Endian-Bytereihenfolge natürlich das Gegenteil von Big-Endian.

Host-Byte-Reihenfolge

stellt die Byte-Reihenfolge der Maschine in diesem Jahr dar (dh die Netzwerk-Byte-Reihenfolge wird bestimmt und der Host Byte-Reihenfolge Die Reihenfolge wird von der Maschine bestimmt), im Allgemeinen Little-Endian.

a und A (gepackte Zeichenfolge, gefüllt mit NUL oder Leerzeichen)

$string = pack('a6', 'china’);
var_dump($string); //输出结果: string(6) "china",最后一个字节是不可见的NUL
echo ord($string[5]); //输出结果: 0(ASCII码中0对应的就是nul)

//A同理
$string = pack('A6', 'china’);
var_dump($string); //输出结果: string(6) "china ",最后一个字节是空格
echo ord($string[5]); //输出结果: 32(ASCII码中32对应的就是空格)

[Bild-Upload fehlgeschlagen...(image-5d8a61 - 1577941896554)]

Kommt mit einer ASCII-Tabelle (Sie können man ascii verwenden, um sie unter Linux/Unix anzuzeigen)

h und H

$string = pack('H3', 281);
var_dump($string); //输出结果: string(2) “(“
for($i=0;$i<strlen($string);$i++) {
echo ord($string[$i]) . PHP_EOL;
}
//输出结果: 40 16

H und H bedürfen einer besonderen Erklärung. Sie behandeln die entsprechenden Parameter als Hexadezimalzeichen und verpacken sie dann. Was bedeutet es? Beispielsweise wird die obige 281 vor dem Packen in 0x281 konvertiert, da eine hexadezimale Ziffer vier Binärziffern entspricht. Die obige 0x281 ist nur 1,5 Bytes groß und wird standardmäßig durch 0 ergänzt, um 0x2810 zu erhalten, wobei die Dezimalzahl 0x28 entspricht. ist 40((), die Dezimalzahl, die 0x10 entspricht, ist 16 (unsichtbares Zeichen).

c und C

$string = pack(&#39;c3&#39;, 67, 68, -1);
var_dump($string); //输出:string(3) “CD�”
for($i=0;$i<strlen($string);$i++) {
echo ord($string[$i]) . PHP_EOL;
}
//输出: 67 68 225

Endlich Instinkt ausgeben Es sollte angenommen werden, dass es 67 68 -1 ist

ord erhält den ASCII-Code des Zeichens (Bereich 0-255). Zu diesem Zeitpunkt wird das Zeichen ausgegeben, das -1 (0000 0001) entspricht die Form des Komplements, die 255 ( 1111 1110 + 0000 0001 = 1111 1111) ist

Ganzzahlbezogen

Alle Ganzzahltypen werden exakt verwendet Achten Sie auf die gleiche Weise hauptsächlich auf ihre Bit- und Byte-Reihenfolge. L wird unten als Beispiel verwendet:

$string = pack(&#39;L&#39;, 123456789);
var_dump($string); //输出:string(4) “�[“

for($i=0;$i<strlen($string);$i++) {
echo ord($string[$i]) . PHP_EOL;
}
//输出: 21 205 91 7

f und d

$string = pack(&#39;f&#39;, 12345.123);
var_dump($string);
//输出:string(4) "~�@F”
var_dump(unpack(&#39;f&#39;, $string)); //这里提前用到了unpack,后面会讲解
//输出:float(12345.123046875)

f und d stehen für das Verpacken von Gleitkommazahlen. Warum es vor dem Verpacken 12345,123 und nach dem Entpacken 12345,123046875 ist, hat dies etwas mit der Speicherung von Gleitkommazahlen zu tun

x,

$string = pack(&#39;x&#39;); //打包一个nul字符串
echo ord($string); //输出: 0
Über Während des Packens werden die Parameter zum Entpacken verwendet. Ich bin zu faul, um die spezifische Verwendung aufzulisten:

$string = pack(&#39;Z2&#39;, &#39;abc5&#39;); //其实就是将从Z后面的数字位置开始,全部设置为nul
var_dump($string); //输出:string(2) “a”
for($i=0;$i<strlen($string);$i++) {
echo ord($string[$i]) . PHP_EOL;
}
//输出: 97 0

Was sind die Verwendungszwecke dieser beiden Funktionen?

·

Datenkommunikation (Kommunikation mit anderen Sprachen über Binärformat)

·

Datenverschlüsselung (wenn Sie dem Dritten Ihre Verpackungsmethode nicht mitteilen, wird es für die andere Partei schwieriger, sie auszupacken. Relativ groß)

·Speichern Sie Platz (wenn Sie beispielsweise relativ große Zahlen als Zeichenfolgen speichern, wird viel Platz verschwendet, und es sind nur 4 Ziffern erforderlich, um sie in das Binärformat )

Die chinesische PHP-Website bietet eine große Anzahl kostenloser PHP-Einführungs-Tutorials, die jeder gerne lernen kann!

Dieser Artikel wurde reproduziert von: https://www.jianshu.com/p/942907071a4c

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Verwendung von Pack- und Unpack-Funktionen in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:jianshu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen
Vorheriger Artikel:Chatlistenzeit formatierenNächster Artikel:Chatlistenzeit formatieren