这是太多行和太多嵌套块了吗?

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

Object Calisthenics

另外PHP Coding Standards Fixer是你的朋友。

所以:

  • 您当前的代码完全没问题
  • 创建您的个人偏好并尽量减少 possible.
  • 的嵌套和行数