PHP ist eine serverseitige Skriptsprache, die im Bereich der Webentwicklung weit verbreitet ist. Auch die Verarbeitung von Zahlenoperationen ist ein wichtiger Bestandteil von PHP. Bei digitalen Operationen sind Basiskonvertierung und Komplement zwei Schlüsselkonzepte. In diesem Artikel werden die grundlegenden Konvertierungs- und Füllvorgänge in PHP ausführlich vorgestellt, um den Lesern zu helfen, diese beiden Vorgänge besser zu verstehen und zu verwenden.
1. Basiskonvertierung
1.1 Dezimalzahlen in andere Basen umwandeln
PHP bietet Funktionen zum Konvertieren von Dezimalzahlen in andere Basen, von denen die am häufigsten verwendeten Funktionen decbin(), decoct() und dechex() sind. Diese Funktionen konvertieren Dezimalzahlen in binäre, oktale bzw. hexadezimale Zeichenfolgen und geben die Ergebnisse zurück.
Der Beispielcode lautet wie folgt:
$decimal_num = 35; $bin_num = decbin($decimal_num); // 二进制 $oct_num = decoct($decimal_num); // 八进制 $hex_num = dechex($decimal_num); // 十六进制 echo "{$decimal_num}的二进制是:{$bin_num}\n"; // 输出35的二进制 echo "{$decimal_num}的八进制是:{$oct_num}\n"; // 输出35的八进制 echo "{$decimal_num}的十六进制是:{$hex_num}\n"; // 输出35的十六进制
Das Ausgabeergebnis lautet wie folgt:
35的二进制是:100011 35的八进制是:43 35的十六进制是:23
1.2 Konvertieren anderer Basen in Dezimalzahlen
Der Konvertierung von Dezimalzahlen in andere Basen entspricht der Vorgang der Konvertierung anderer Basiszahlen in Dezimalzahlen PHP Es werden auch entsprechende Funktionen bereitgestellt, nämlich die Funktionen bindec(), octdec() und hexdec(). Diese Funktionen konvertieren binäre, oktale und hexadezimale Zeichenfolgen in dezimale Ganzzahlen und geben die Ergebnisse zurück.
Der Beispielcode lautet wie folgt:
$bin_num = '100011'; $oct_num = '43'; $hex_num = '23'; $decimal_num_from_bin = bindec($bin_num); // 二进制转十进制 $decimal_num_from_oct = octdec($oct_num); // 八进制转十进制 $decimal_num_from_hex = hexdec($hex_num); // 十六进制转十进制 echo "{$bin_num}的十进制是:{$decimal_num_from_bin}\n"; // 输出二进制的十进制转换结果 echo "{$oct_num}的十进制是:{$decimal_num_from_oct}\n"; // 输出八进制的十进制转换结果 echo "{$hex_num}的十进制是:{$decimal_num_from_hex}\n"; // 输出十六进制的十进制转换结果
Das Ausgabeergebnis lautet wie folgt:
100011的十进制是:35 43的十进制是:35 23的十进制是:35
2. Ausfülloperation
In Computern werden digitale Speicherung und Operationen häufig in binärer Form ausgeführt. Manchmal müssen wir Binärzahlen „füllen“, also das höchste Bit mit 0 oder 1 füllen, um die Berechnungsanforderungen bestimmter Arten von Rechenoperationen zu erfüllen. Die in PHP bereitgestellte Bitset-Bibliothek kann solche „Bitfüllvorgänge“ ausführen.
2.1 Installieren Sie die Bitset-Bibliothek
Um die Bitset-Bibliothek verwenden zu können, müssen Sie die Bibliothek zuerst installieren. Die Installationsschritte sind wie folgt:
Schritt 1: Führen Sie den folgenden Befehl im Terminal aus, um die Bitset-Bibliothek zu installieren:
composer require lucasassis/bitset
Schritt 2: Verweisen Sie auf den vom Composer automatisch generierten Autoloader im Code:
require 'vendor/autoload.php';
2.2 Erstellen Sie eine Bitsammlung
Verwenden der Bitset-Bibliothek Bevor Sie den Bitfüllvorgang durchführen, müssen Sie einen Bitsatz (dh Bitsatz) erstellen. Ein Bitsatz ist eine Sammlung aufeinanderfolgender Bits, wobei jedes Bit ein binäres Symbol 0 oder 1 ist.
Die Funktion zum Erstellen eines Bitsatzes ist BitSet::create() und ihr Parameter ist die Gesamtzahl der Bits, die eine Ganzzahl oder eine Zeichenfolge sein kann.
Der Beispielcode lautet wie folgt:
use Lucasassis\BitSet; $num_of_bits = 8; // 位数 $bitset = BitSet::create($num_of_bits); // 创建8位的bitset echo "创建的{$num_of_bits}位bitset为:{$bitset}\n";
Das Ausgabeergebnis lautet wie folgt:
创建的8位bitset为:00000000
2.3 Füllvorgang
Wenn das Bit gesetzt ist, kann der Füllvorgang ausgeführt werden. Beispielsweise muss bei der Berechnung der binären Addition 1 der Operand (d. h. die Zahl, die 1 addiert werden soll) „zurückgegeben und 1 addiert“ werden, um das korrekte Ergebnis der Addition von 1 zu erzielen.
Der Beispielcode lautet wie folgt:
use Lucasassis\BitSet; $num_of_bits = 8; // 位数 $number = 35; // 要进行加1操作的数字 $bitset = BitSet::create($num_of_bits); // 创建8位的bitset $bitset->setValue($number); // 将$number值存入bitset中 echo "原数字:{$number},补位结果:"; echo $bitset->not()->add(1)->asBinaryString(); // 取反加1,输出结果
Das Ausgabeergebnis lautet wie folgt:
原数字:35,补位结果:00100010
Im obigen Code wird die Funktion BitSet::setValue() verwendet, um die Zahl im Übertragssatz zu speichern, und das BitSet: Die Funktion :not() wird verwendet, um die Inversionsoperation durchzuführen. Die Funktion BitSet::add() wird verwendet, um 1 zu addieren, und die Funktion BitSet::asBinaryString() wird verwendet, um das Ergebnis der Binärzeichenfolge auszugeben.
3. Zusammenfassung
In diesem Artikel werden die Basiskonvertierungs- und Bitfülloperationen in PHP vorgestellt. Die Basiskonvertierung ist ein wichtiges Konzept im Computerbetrieb und spielt eine wichtige Rolle bei der Darstellung und Verarbeitung digitaler Daten. Die Fülloperation ist eine Operation, die häufig in bestimmten Algorithmen verwendet wird, um die Ergebnisse digitaler Datenoperationen zu verbessern. Ich hoffe, dass dieser Artikel den Lesern helfen kann, diese beiden Operationen besser zu verstehen und anzuwenden.
Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Hexadezimalkonvertierung und das Ausfüllen von Bits in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!