<?php $foo = 1; $bar = $foo; echo $foo + $bar;
变量 $foo 赋值给变量 $bar,这两个变量具备相反的值,不须要新请求内存空间,他们能够同享同一块内存。正在不少场景下PHP 的 COW 对内存进行优化。比方:变量的屡次赋值、函数参数通报,并正在函数体内修正实参等。
甚么是“复制”
这是一段摘自鸟哥博客的例子,说的比拟分明,就间接贴过去了。
<?php $var = "laruence"; $var_dup = $var; $var = 1; ?>
很显著正在这段代码执行当前,$var_dup 的值应该仍是”laruence”, 那末这又是怎样完成的呢?这就是 PHP 的 copy on write 机制:
PHP 正在修正一个变量之前,会起首查看这个变量的 refcount,假如 refcount 年夜于1,PHP 就会执行一个别离的例程, 关于下面的代码,当执行到第三行的时分,PHP 发现 $var 指向的 zval 的 refcount 年夜于1,那末 PHP 就会复制一个新的 zval 进去,将原 zval 的 refcount 减 1,并修正 symbol_table,使患上 $var 以及 $var_dup 别离(Separation)。这个机制就是所谓的 copy on write(写时复制)。
写时复制使用场景
写时复制(Copy on Write,也缩写为COW)的使用场景十分多, 比方Linux中对过程复制中内存应用的优化,正在各类编程言语中,如C++的STL等等中均有相似的使用。 COW是罕用的优化手法,能够归类于:资本提早调配。只有正在真正需求应用资本时才占用资本, 写时复制通常能缩小资本的占用。
一个证实 PHP COW 优化内存占用的例子:
<?php $j = 1; var_dump(memory_get_usage()); $tipi = array_fill(0, 100000, 'php-internal'); var_dump(memory_get_usage()); $tipi_copy = $tipi; var_dump(memory_get_usage()); foreach ($tipi_copy as $i) { $j += count($i); } var_dump(memory_get_usage());
运转后果:
$ php t . php int(630904) int(10479840) int(10479944) int(10480040)
内存并无明显进步。
“写时复制”的原理
多个相反值的变量共用同一块内存确实节流了内存空间,但变量的值是会发作变动的,假如正在下面的例子中, 指向同一内存的值发作了变动(或许可能发作变动),就需求将变动的值“别离”进来,这个“别离”的操作, 就是“复制”。
正在PHP中,Zend引擎为了区分同一个zval地点能否被多个变量同享,引入了ref_count以及is_ref两个变量进行标识:
ref_count以及is_ref是界说于zval构造体中
is_ref标识是否是用户应用 & 的强迫援用;
ref_count是援用计数,用于标识此zval被几何个变量援用,即COW的主动援用,为0时会被销毁;
注:因而可知, $a=$b; 与 $a=&$b; 正在PHP对内存的应用上不区分(值没有变动时);
置信各人也能够理解到PHP中COW的完成原理: PHP 中的 COW 基于援用计数ref_count 以及 is_ref 完成, 多一个变量指针,就将 ref_count 加 1, 反之减去 1,减到 0 就销毁; 同理,多一个强迫援用 &,就将 is_ref 加 1,反之减去 1。
以上就是PHP写时复制(Copy On Write)的具体内容,更多请存眷资源魔其它相干文章!
标签: php php开发教程 php开发资料 php开发自学
抱歉,评论功能暂时关闭!