我对 PHP 比较陌生,并且正在慢慢学习特定于该语言的特性。我被很多人讨厌的一件事是我(有人告诉我)使用了太多的函数调用,并且通常被要求做一些事情来解决它们。这里有两个例子:
// Change this:
} catch (Exception $e) {
print "It seems that error " . $e->getCode() . " occured";
log("Error: " . $e->getCode());
}
// To this:
} catch (Exception $e) {
$code = $e->getCode();
print "It seems that error " . $code . " occured";
log("Error: " . $code);
}
第二个例子
// Change this:
$customer->setProducts($products);
// To this:
if (!empty($products)) {
$customer->setProducts($products);
}
在第一个示例中,我发现分配$e->getCode()
给$code
广告会产生轻微的认知开销;“'$code'是什么?啊,这是异常的代码。” 而第二个例子增加了圈复杂度。在这两个示例中,我发现优化是以牺牲可读性和可维护性为代价的。
性能提升值得还是这种微优化?
我应该注意到,我们现在坚持使用 PHP 5.2。
我进行了一些非常粗略的基准测试,发现函数调用性能命中率约为 10% 到 70%,具体取决于基准测试的性质。我承认这很重要。但在那个 catch 块被命中之前,有一个对数据库和 HTTP 端点的调用。在$products
设置之前,数组$customer
发生了复杂的排序。归根结底,这种优化是否证明了使代码更难阅读和维护的成本是合理的?或者,尽管这些示例是简化的,但是否有人发现第二个示例与第一个示例一样容易或更容易阅读(我是维纳)?$products
任何人都可以引用任何关于此的好文章或研究吗?
编辑:
一个示例台架测试:
<?php
class Foo {
private $list;
public function setList($list) {
$this->list = $list;
}
}
$foo1 = new Foo();
for($i = 0; $i < 1000000; $i++) {
$a = array();
if (!empty($a))
$foo1->setList($a);
}
?>
使用命令运行该文件time
。在一台特定的机器上,几次运行后平均需要 0.60 秒。注释掉if (!empty($a))
导致它平均需要 3.00 秒才能运行的原因。
澄清:这些是例子。第一个示例演示了可怕的异常处理和可能的 DRY 违规,代价是一个简单的、非特定于域的示例。