erlchina 发表于 2015-8-26 10:56:37

PHP:引用是个坏习惯

  这篇文章,写的比较早,有一些错误的说法,我表示非常歉意。一些代码,没有经过严格的测试,以后写博客一定要非常谨慎。因为可能会对一些人产生误导。
  在写PHP 程序的时候,很多人在传递参数的时候,喜欢用一个引用。特别是在一个数组非常的大的时候,更是喜欢加。


function binsearch(&$arr, $key, $value)
{
    $low = 0;
    $high = count($arr);
    while ($low <= $high) {
   $mid = floor($low + ($high - $low) / 2);
   $item = $arr[$mid][$key];
   if ($item == $value) {
       return $mid;
   } else if ($value > $item) {
      $low = $mid + 1;
   } else {
         $high = $mid - 1;
   }
    }
    return false;
}
  
  在这里,$mid 采用了先减后加的方法计算,目的是为了防止整数的溢出。不是故意写复杂了。
  
  我用下面的代码进行测试:
  $data = array();
for ($i = 0; $i < 1000000; $i++)
{
    $data[] = array("sq" => $i * 2);
}
var_dump(binsearch($data, "sq", 10000));
  发现,binsearch 的时候,总是要花个 0.2s左右。理论上来说,100万的数据,最多也就是循环20次。怎么会这样慢呢。
  
  后来监控了一下内存,data 数组 占用了 230M 的内存。而 binsearch 的时候,占用了60K 的内存。但是,理论上来说,binsearch
  不应该占用如此多的内存。因为,我觉得,我已经用引用了,根本就没有对data 的结构进行修改。
  
  我也是百思不得其解,后来,我把引用参数去掉,居然 binsearch只要 0.0002s ,看来是引用耗费了大量的cpu 资源。
  
  PHP 内部遵循一个copy on write 的原则。实际上这个引用是多余的。
  但是为什么,加了引用速度会变慢呢?今天重点就谈谈这个问题。明白道理后,大家一定知道怎么用引用了。
  这个问题,实际上涉及了zend 引擎如何管理PHP变量。
  具体的也可以阅读这篇博客:
深入PHP内核(1) 引用
  
  主要技术count 的时候,出了问题,要进行复制。
页: [1]
查看完整版本: PHP:引用是个坏习惯