这是太多行和太多嵌套块了吗?
Is this too many lines and too many nested blocks?
我有一个函数可以从数据库加载事物列表并将它们放入 select 列表中。函数如下:
(伪代码)
protected function Foo()
{
try {
get pdo instance
prepare statement
if (pdo query executes)
{
while (row = fetched rows)
{
do stuff with row
}
}
}
catch (PDOException $ex)
{
do error stuff here
}
}
NetBeans 给出代码提示,提示行数过多,嵌套块过多。个人觉得功能应该可以接受。我还觉得将逻辑分解成更小的函数有点疯狂,但为什么 netbeans 会骗我:)?
所以我的问题如下:
这是错误的逻辑还是我可以继续?
我欢迎任何关于如何重新设计函数以适应 NetBean 约束的建议。
编辑:
我不会回答我自己的问题,但在这种情况下,有一个不需要的嵌套块。 pdo 是从具有 try/catch 块的单例 class 中检索的。我不需要在这个函数中再次重复它,因为异常已经被捕获了。
编辑 2:
删除 try catch 块就像以盗窃罪来支付保罗。因此,如果在创建 pdo 实例时抛出异常,它不会停止执行。因此,我们尝试在未正确初始化的 PDO 对象上调用 prepare 语句。这迫使我们在 prepare 调用之前进行另一个测试,从而返回到对原始函数的返工。
根据我的经验,这意味着我的逻辑在某处被打断了。如果我有什么值得说的,我将回顾我的设计并回头。
再次感谢大家
如果条件不为真,你可以反转if语句并退出函数,以消除一层嵌套。不过逻辑看起来也不错。
你的代码很好。 NetBeans 建议的不一定是您应该遵循的规则,如果您使用其他编辑器,如 PHPStorm,您甚至不会担心(在 PHPStorm 中,您可以将编码风格设置为遵循 PSR 1/2)。
你至少可以通过使用一种叫做 guard clause:
的东西来消除一个嵌套
protected function Foo()
{
try {
get pdo instance
prepare statement
if (! pdo query executes) return;
while (row = fetched rows)
{
do stuff with row
}
}
catch (PDOException $ex)
{
do error stuff here
}
}
我看到人们有不同的偏好,因为没有硬性规定。例如 Anthony Ferrara personally thinks 他不应超过四个嵌套级别,我个人认为四个级别太多了。
重点是您应该尽可能减少嵌套和行数。当你的方法太大时(有时被称为神法),说明你做错了。
您可能还想看看 William Durand 撰写的这篇精彩文章,其中他讨论了 Jeff Bay 在他的书中提出的几个(实际上是 9 个)提案 ThoughtWorks Anthology
另外PHP Coding Standards Fixer是你的朋友。
所以:
- 您当前的代码完全没问题
- 创建您的个人偏好并尽量减少 possible.
的嵌套和行数
我有一个函数可以从数据库加载事物列表并将它们放入 select 列表中。函数如下: (伪代码)
protected function Foo()
{
try {
get pdo instance
prepare statement
if (pdo query executes)
{
while (row = fetched rows)
{
do stuff with row
}
}
}
catch (PDOException $ex)
{
do error stuff here
}
}
NetBeans 给出代码提示,提示行数过多,嵌套块过多。个人觉得功能应该可以接受。我还觉得将逻辑分解成更小的函数有点疯狂,但为什么 netbeans 会骗我:)?
所以我的问题如下:
这是错误的逻辑还是我可以继续? 我欢迎任何关于如何重新设计函数以适应 NetBean 约束的建议。
编辑:
我不会回答我自己的问题,但在这种情况下,有一个不需要的嵌套块。 pdo 是从具有 try/catch 块的单例 class 中检索的。我不需要在这个函数中再次重复它,因为异常已经被捕获了。
编辑 2:
删除 try catch 块就像以盗窃罪来支付保罗。因此,如果在创建 pdo 实例时抛出异常,它不会停止执行。因此,我们尝试在未正确初始化的 PDO 对象上调用 prepare 语句。这迫使我们在 prepare 调用之前进行另一个测试,从而返回到对原始函数的返工。
根据我的经验,这意味着我的逻辑在某处被打断了。如果我有什么值得说的,我将回顾我的设计并回头。
再次感谢大家
如果条件不为真,你可以反转if语句并退出函数,以消除一层嵌套。不过逻辑看起来也不错。
你的代码很好。 NetBeans 建议的不一定是您应该遵循的规则,如果您使用其他编辑器,如 PHPStorm,您甚至不会担心(在 PHPStorm 中,您可以将编码风格设置为遵循 PSR 1/2)。
你至少可以通过使用一种叫做 guard clause:
的东西来消除一个嵌套protected function Foo()
{
try {
get pdo instance
prepare statement
if (! pdo query executes) return;
while (row = fetched rows)
{
do stuff with row
}
}
catch (PDOException $ex)
{
do error stuff here
}
}
我看到人们有不同的偏好,因为没有硬性规定。例如 Anthony Ferrara personally thinks 他不应超过四个嵌套级别,我个人认为四个级别太多了。
重点是您应该尽可能减少嵌套和行数。当你的方法太大时(有时被称为神法),说明你做错了。
您可能还想看看 William Durand 撰写的这篇精彩文章,其中他讨论了 Jeff Bay 在他的书中提出的几个(实际上是 9 个)提案 ThoughtWorks Anthology
另外PHP Coding Standards Fixer是你的朋友。
所以:
- 您当前的代码完全没问题
- 创建您的个人偏好并尽量减少 possible. 的嵌套和行数