Heim  >  Artikel  >  php教程  >  PHP垃圾收集器和程序员的幽默

PHP垃圾收集器和程序员的幽默

WBOY
WBOYOriginal
2016-06-06 20:14:05943Durchsuche

Composer是一个深受程序员喜欢的PHP依赖关系管理工具。最近它的源代码上的一处改动引起了大家热烈的讨论。改动其实只是增加了一行代码: gc_disable(); ,但为什么要增加这行代码的原因却让人很费解。 估计普通的PHP程序员对这行代码并不知道是干嘛的。但单

Composer是一个深受程序员喜欢的PHP依赖关系管理工具。最近它的源代码上的一处改动引起了大家热烈的讨论。改动其实只是增加了一行代码:gc_disable();,但为什么要增加这行代码的原因却让人很费解。

估计普通的PHP程序员对这行代码并不知道是干嘛的。但单从语义的字面意思上可以猜出,它是要禁止PHP的垃圾收集器。没错,就是这个意思。

给那些想寻求技术解释的人说明一下,在Composer里,PHP的垃圾收集器浪费了大量的CUP资源,它试图收集由于Composer在解决程序依赖问题时候产生的成千上万的对象(这些对象是Composer用来表达依赖包内部规则的)。对象在不断的生产,它就一遍又一遍的收集,但事实上它什么都没收集到,但每次对象的生产都会触发它再次收集。

禁止PHP的垃圾收集器虽然阻止了PHP的高级功能,但却释放了大量的内存,这样,Composer有足够的内存来做自己的事情,而不是让它们浪费在什么垃圾都收集不到的活动中。经过这样的修改后,很多人都报告内存使用量大幅度下降。

为什么这个问题这么久了才被人发现?看起来原因是性能优化工具无法检测到垃圾收集器的工作。很显然,这是性能优化工具的问题,期望以后后有所改进。但大多数情况下,这PHP的这个特征并不会成为一个问题,我不建议你们都在自己的项目中禁止垃圾收集器的工作。 在大多数情况下,PHP的垃圾收集器是非常有用的,只是在我们的Composer工具里它出现了问题。

上面的这段话是这段代码的修改人Seldaek在Hacker News上给大家的解释。

说的很清楚明白,消除了大家的疑惑,但这不是本文的重点,本文要说的重点是大家对这一重大修改的反应,全部体现在了Github的评论里。太欢乐了。你会发现程序员是最幽默的,下面选几个例子:

网友clemherreman评论:

Before: Memory usage: 163.66MB (peak: 403.82MB), time: 246.25s
After: Memory usage: 163.34MB (peak: 350.36MB), time: 99.55s

网友martindines评论:

Before: Memory usage: 152.71MB (peak: 335.9MB), time: 195.99s
After: Memory usage: 164MB (peak: 308.02MB), time: 104.06s

网友eXtreme评论:

Before: Memory usage: 217.37MB (peak: 631.42MB), time: 313.4s
After: Memory usage: 174.62MB (peak: 495.42MB), time: 152.3s
After latest commit: Memory usage: 174.88MB (peak: 495.1MB), time: 67.73s

网友j0k3r评论:

Memory usage: 385.05MB (peak: 910.03MB), time: 138.81s
Memory usage: 384.93MB (peak: 863.22MB), time: 26.12s

网友youbs评论:

Before:
Memory usage: 2194.78MB (peak: 3077.39MB), time: 1324.69s
After:
Memory usage: 4542.54MB (peak: 4856.12MB), time: 232.66s

网友johnpbloch评论:

Before: Memory usage: 43.34MB (peak: 69.12MB), time: 26.57s
After: Memory usage: 43.67MB (peak: 60.27MB), time: 7.01s

网友o评论:

Our builds are now faster than ever!

网友oscherler评论:

Before: Memory usage: 272.95MB (peak: 898.45MB), time: 144.32s
After:  Memory usage: 257.05MB (peak: 608.25MB), time: 24.34s

网友raphaelstolt评论:

Memory usage: 94.01MB (peak: 163.47MB), time: 11.24s
Memory usage: 87.91MB (peak: 123.66MB), time: 3.38s

网友malaney评论:

Before:
Memory usage: 207.13MB (peak: 705.58MB), time: 762.59s
After:
Memory usage: 164.42MB (peak: 469.22MB), time: 53.98s

哦,太多了….

你是不是也乐了,这些搞技术的人是多么有趣一群人呀,生活中虽然有些寡言少语,但在工作中,在技术问题上,他们幽默、好学、欢闹的性格才真正的体现出来。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn