Copy-on-Write (auch als COW abgekürzt) kopiert, wie der Name schon sagt, tatsächlich eine Kopie des Speichers zur Änderung beim Schreiben. COW wurde zuerst in *nix-Systemen verwendet, um die Thread- und Speichernutzung zu optimieren, und wurde später häufig in verschiedenen Programmiersprachen wie C++s STL usw. verwendet. Im PHP-Kernel ist COW auch die Hauptmethode zur Speicheroptimierung. In der vorherigen Diskussion über Variablen und Speicher spielt die Referenzzählung eine entscheidende Identifikationsrolle bei der Zerstörung und Wiederverwendung von Variablen. Der Zweck der Referenzzählung besteht darin, COW einen normalen Betrieb zu ermöglichen und so eine optimale Speichernutzung zu erreichen.
Die Rolle von Copy-on-Write
Das Folgende ist ein Codestück:
<?php var_dump(memory_get_usage());//先打印出当前内存情况 $arr = array_fill(0, 100000, 'tioncico');//生成一个0-100000键的数组 var_dump(memory_get_usage());//打印内存 $arr_copy = $arr;//把数组赋值给另一个 var_dump(memory_get_usage());//打印内存 $j=1; foreach($arr_copy as $i) {//循环遍历该数组键值查看内存情况 $j += count($i); } var_dump(memory_get_usage());//打印内存
Mit anderen Worten, selbst wenn wir keine Referenzen verwenden, übergeben PHP-Variablen Werte und weisen Werte zu, die alle auf denselben Speicher verweisen, aber was passiert, wenn sich der Wert von $arr_copy ändert? php5.6-Webumgebung und die Referenzen von php7 sind unterschiedlich)
var_dump(memory_get_usage()); //$tipi = array_fill(0, 3, 'php-internal'); //不用array_fill的原因可自己试着打印下 $tipi[0]='php-internal'; $tipi[1]='php-internal'; $tipi[2]='php-internal'; var_dump(memory_get_usage()); $copy = $tipi; xdebug_debug_zval('tipi', 'copy'); var_dump(memory_get_usage()); $copy[0] = '123'; xdebug_debug_zval('tipi', 'copy'); var_dump(memory_get_usage());
Das ist bei der Zuweisung von $arr zu sehen Wenn Sie den Wert auf $arr_copy setzen, gibt es keine offensichtliche Änderung im Ausführungsspeicher. Erhöhen Sie die Speichermenge direkt um 5443320
Auch beim anschließenden foreach-Durchlauf wird der Speicher nicht erhöht.
Denn wenn $arr $arr_copy zugewiesen wird, wird nicht der gesamte Wert von $arr in den Speicher kopiert, sondern der Wert von $arr_copy wird auf $arr verwiesen, was dem Abrufen von entspricht Daten von $arr_copy, es zeigt immer noch auf den Speicher, in dem $arr den Wert speichert Mit anderen Worten, auch wenn wir keine Referenzen verwenden, wenn PHP-Variablen Werte übergeben und Werte zuweisen, sind sie alle zeigen auf denselben Speicher, aber was passiert, wenn sich der Wert von $arr_copy ändert
|
Die Ergebnisse sind wie folgt: (Hinweis: Dieses Ergebnis befindet sich in der PHP5.6-Webumgebung und die Referenzen von PHP7 sind unterschiedlich)
Das ist zu sehen, wenn Wenn sich der Wert von $copy[0] ändert, wendet PHP erneut Speicher für $copy[0] an und weist ihm dann einen neuen Wert zu, hat jedoch keinen Einfluss auf den Speicherstatus anderer Werte. Die minimale Granularität von Copy-on-Write ist die zval-Struktur. Bei Sammlungen von zval-Strukturen (wie Arrays und Objekten usw.) werden komplexe Objekte zur Verarbeitung in die kleinste Granularität zerlegt, wenn Speicher kopiert werden muss. Wenn ein bestimmter Teil eines komplexen Objekts im Speicher geändert wird, ist es auf diese Weise nicht erforderlich, alle Elemente des Objekts in einer Speicherkopie zu „separieren“, wodurch Speicherverbrauch gespart wird.
(xdebug_debug_zval im Artikel ist eine Funktion in der xdebug-Erweiterung, die zum Anzeigen der Referenzinformationen von Variablen verwendet wird)
Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung des phpCOW-Mechanismus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!