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
哦,太多了….
你是不是也乐了,这些搞技术的人是多么有趣一群人呀,生活中虽然有些寡言少语,但在工作中,在技术问题上,他们幽默、好学、欢闹的性格才真正的体现出来。
原文地址:PHP垃圾收集器和程序员的幽默, 感谢原作者分享。