php垃圾回收机制 鸟哥,PHP之脚本的内存管理和垃圾回收

本篇文章给大家分享了关于PHP之脚本的内存管理和垃圾回收 ,通过实例来给大家展示了PHP之脚本的内存管理和垃圾回收 ,有需要的朋友可以参考一下。

引用赋值$a = 'apple';

$b = &$a;

上述代码中,我将一个字符串赋值给变量a,然后将a的引用赋值给了变量b。显然,这个时候的内存指向应该是这样的:$a -> 'apple'

a和b指向了同一块内存区域(变量容器),我们通过 var_dump($a, $b) 得到 string(5) "apple" string(5) "apple" ,这是我们预期的结果。

引用计数 与 unset( )

假如我想将 'apple' 这个字符串从内存中释放掉。我是这么做的:unset($a);

但是通过再次打印 $a $b 两变量的信息,我得到了这样的结果:Notice: Undefined variable: a 和 string(5) "apple" 。奇怪,$a $b 同时指向一块内存区域,又明明将$a释放了,为什么$b还是'apple'。

其实是这样的,unset()这是将一个变量指针销毁了,并没有释放掉那块内存区域(变量容器),所以执行完操作之后,内存指向只是变成了这样:'apple'

要牢记重点: unset()并没有释放变量所指向的那块内存(变量容器),而只是将变量指针销毁了。同时,将那块内存的 引用计数 (ref count) 减1,当引用计数为0时,也就是说当那块内存(变量容器)不被任何变量引用时,便会触发php的垃圾回收。

用代码来验证一下:$a = 'apple';

$b = &$a;

$before = memory_get_usage();

unset($a);

$after = memory_get_usage();

var_dump($before - $after); // 结果为int(0),没有释放$a = 'apple';

$b = &$a;

$before = memory_get_usage();

unset($a, $b);

$after = memory_get_usage();

var_dump($before - $after); // 结果为int(24),得到释放

直接回收

那要怎样做才能真正释放掉 'apple' 所占用的内存呢?

利用上述方法,我们可以在 unset($a) 之后再 unset($b) ,将内存区域的所有引用都销毁,引用计数减为0了,自然就被php回收了。

当然,还有更直接的方法:$a = null;

直接赋值 null 会将将 $a 所指向的内存区域置空,并将引用计数归零,内存便被释放。

脚本执行结束

php是脚本语言,当脚本执行结束之后,脚本内使用的所有内存都会被释放。那么,我们手动去释放内存有意义吗?其实关于这个问题,早有解答,推荐大家看一下鸟哥 @laruence 2012年发表的一篇文章:请手动释放你的资源(Please release resources manually)

引用赋值$a = 'apple';

$b = &$a;

上述代码中,我将一个字符串赋值给变量a,然后将a的引用赋值给了变量b。显然,这个时候的内存指向应该是这样的:$a -> 'apple'

a和b指向了同一块内存区域(变量容器),我们通过 var_dump($a, $b) 得到 string(5) "apple" string(5) "apple" ,这是我们预期的结果。

引用计数 与 unset( )

假如我想将 'apple' 这个字符串从内存中释放掉。我是这么做的:unset($a);

但是通过再次打印 $a $b 两变量的信息,我得到了这样的结果:Notice: Undefined variable: a 和 string(5) "apple" 。奇怪,$a $b 同时指向一块内存区域,又明明将$a释放了,为什么$b还是'apple'。

其实是这样的,unset()这是将一个变量指针销毁了,并没有释放掉那块内存区域(变量容器),所以执行完操作之后,内存指向只是变成了这样:'apple'

要牢记重点: unset()并没有释放变量所指向的那块内存(变量容器),而只是将变量指针销毁了。同时,将那块内存的 引用计数 (ref count) 减1,当引用计数为0时,也就是说当那块内存(变量容器)不被任何变量引用时,便会触发php的垃圾回收。

用代码来验证一下:$a = 'apple';

$b = &$a;

$before = memory_get_usage();

unset($a);

$after = memory_get_usage();

var_dump($before - $after); // 结果为int(0),没有释放$a = 'apple';

$b = &$a;

$before = memory_get_usage();

unset($a, $b);

$after = memory_get_usage();

var_dump($before - $after); // 结果为int(24),得到释放

直接回收

那要怎样做才能真正释放掉 'apple' 所占用的内存呢?

利用上述方法,我们可以在 unset($a) 之后再 unset($b) ,将内存区域的所有引用都销毁,引用计数减为0了,自然就被php回收了。

当然,还有更直接的方法:$a = null;

直接赋值 null 会将将 $a 所指向的内存区域置空,并将引用计数归零,内存便被释放。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值