if && else if优化

完全不必要的 Else 块

  1. 这也许是那些初级开发人员最负罪的之一。下面的示例很好地说明了当你被认为 If-Else 很棒时会发生什么
// Simple if-else
public void PerformOperation(int input) {
        if (input > 5) {
            // do something
        } else {
            // do something else
        }
    }
  1. 只需删除 else` 块即可简化此过程,如下图:
// Removed else
public void PerformOperation01(int input) {
	if (input > 5) {
		// do something
		return;
	}
	// do something else
}
  1. 看起来更专业吧?你会发现,实际上根本不需要其他块。像在这种情况下一样,你想要在满足特定条件的情况下执行某些操作并立即返回。

价值分配

  1. 如果你要根据提供的某些输入为变量分配新值,请停止 If-Else 废话,一种更具可读性的方法。
    • Value assignment with if-else

  2. 尽管很简单,但它却很糟糕。首先,If-Else 很容易在这里被开关取代。但是,我们可以通过完全删除 else 来进一步简化此代码。
    • If statements with fast return

  3. 如果不使用 else,则我们将剩下干净的可读代码。请注意,我也将样式更改为快速返回而不是单返回语句。如果已经找到正确的值,继续测试一个值根本没有意义。

前提条件检查

  1. 通常,我发现,如果方法提供了无效的值,则继续执行是没有意义的。假设我们从以前就有了 DefineGender 方法,要求提供的输入值必须始终为 0 或 1。

    • Method without value checks

  2. 在没有价值验证的情况下执行该方法没有任何意义。因此,在允许方法继续执行之前,我们需要检查一些先决条件。

    • 应用保护子句防御性编码技术,你将检查方法的输入值,然后继续执行方法。
    • Check preconditions with guard clauses

  3. 至此,我们确保仅在值落在预期范围内时才执行主逻辑。现在,IF 也已被三元代替,因为不再需要在结尾处默认返回"未知"。

原文地址:https://www.cnblogs.com/Twittery/p/14301196.html