这篇文章主要介绍了关于php引用变量知识详解,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下
概念:在PHP中引用意味着用不同的名字访问同一个变量内容;
定义方式:PHP使用 ‘&’定义引用变量;
当不使用引用时,变量采取写时复制机制机制(COW):在写入时会复制一份内存进行修改,例如
//定义一个变量 $a = range(0,1000); var_dump(memory_get_usage()); //打印内存使用量 //定义一个变量b $b = $a; //此时$b和$a 指向同一个内存空间 var_dump(memory_get_usage()); //当a或b发生写入时,才会复制一块内存进行修改 $a = range(0,1000); var_dump(memory_get_usage());
运行结果:第一次和第二次打印时内存使用量相差不多,第三次发生明显变化,说明当a进行写入操作时,内存发生了复制。
立即学习“PHP免费学习笔记(深入)”;

而当时用引用时变量将指向同一内存空间,写入操作时不会发生改变
//定义一个变量 $a = range(0,1000); var_dump(memory_get_usage()); //打印内存使用量 //定义一个变量b $b = &$a; //将a的空间赋值给b,a与b指向同一空间 var_dump(memory_get_usage()); //当a或b发生写入时,内存不会发生复制 $a = range(0,1000); var_dump(memory_get_usage());
运行结果:内存始终未发生明显变化

通过zval变量容器进行验证
系统功能强大、操作便捷并具有高度延续开发的内容与知识管理系统,并可集合系统强大的新闻、产品、下载、人才、留言、搜索引擎优化、等功能模块,为企业部门提供一个简单、易用、开放、可扩展的企业信息门户平台或电子商务运行平台。开发人员为脆弱页面专门设计了防刷新系统,自动阻止恶意访问和攻击;安全检查应用于每一处代码中,每个提交到系统查询语句中的变量都经过过滤,可自动屏蔽恶意攻击代码,从而全面防止SQL注入攻击
//通过zval变量容器打印
$a = range(0,3);
xdebug_debug_zval('a');//打印 指向内存空间的变量数,和是否被引用
$c =&$a;
xdebug_debug_zval('a');
$c = range(0,3);
xdebug_debug_zval('a');运行结果:
当对c进行写入操作时仍有2个变量指向内存,未发生写时复制

unset只会取消引用,不会销毁空间
在php中对象本身就是引用传值,不需使用引用符号
class Person{
public $name = "zhangsan";
}
$p1 = new Person();
xdebug_debug_zval('p1');
$p2 = $p1;
xdebug_debug_zval('p1');
$p2->name = "lesi";
xdebug_debug_zval('p1');
相关推荐:










