java如何消除太多的if else判斷示例代碼
1.簡介
if判斷語句是很多編程語言的重要組成部分。但是,若我們最終編寫了大量嵌套的if語句,這將使得我們的代碼更加復(fù)雜和難以維護(hù)。
讓我們看看能否使用別的方式來做呢。
設(shè)計模式是為了更好的代碼重用性,可讀性,可靠性,可維護(hù)性,它有六大原則:
- 單一職責(zé)原則(Single Responsibility Principle,簡稱SRP):該原則是針對類來說的,即一個類應(yīng)該只負(fù)責(zé)一項職責(zé).
- 開放--封閉原則(The Open-Closed Principle簡稱OCP):是說軟件實(shí)體(類、模塊、函數(shù)等等)應(yīng)該可以擴(kuò)展,但是不可以修改。
- 依賴倒轉(zhuǎn)原則(Dependence Inversion Principle :針對接口編程,不要對實(shí)現(xiàn)編程
- 里氏代換原則(Liskov Substitution Principle,簡稱LSP):里氏代換原則,子類型必須能夠替換掉他們的父類型
- 迪米特法則(Law of Demeter):如果兩個類不必彼此直接通信,那么這兩個類就不應(yīng)當(dāng)發(fā)生直接的相互作用
- 合成/聚合復(fù)用原則(Composition/Aggregation Principle],簡稱CARP):盡量使用合成/聚合,盡量不使用類繼承。合成聚合是“has a”的關(guān)系,而繼承是“is a”的關(guān)系。
2.示例if..else
public int calculate(int a, int b, String operator) {
int result = Integer.MIN_VALUE;
if ("add".equals(operator)) {
result = a + b;
} else if ("multiply".equals(operator)) {
result = a * b;
} else if ("divide".equals(operator)) {
result = a / b;
} else if ("subtract".equals(operator)) {
result = a - b;
} else if ("modulo".equals(operator)) {
result = a % b;
}
return result;
}
switch-case
public int calculateUsingSwitch(int a, int b, String operator) {
int result = 0;
switch (operator) {
case "add":
result = a + b;
break;
case "multiply":
result = a * b;
break;
case "divide":
result = a / b;
break;
case "subtract":
result = a - b;
break;
case "modulo":
result = a % b;
break;
default:
result = Integer.MIN_VALUE;
}
return result;
}
3.重構(gòu)
3.1 工廠方式重構(gòu)
抽象層Operation.java
public interface Operation {
int apply(int a, int b);
}
加法實(shí)現(xiàn)Addition.java:
public class Addition implements Operation {
@Override
public int apply(int a, int b) {
return a + b;
}
}
減法實(shí)現(xiàn)Subtraction.java
public class Subtraction implements Operation {
@Override
public int apply(int a, int b) {
return a - b;
}
}
乘法實(shí)現(xiàn)Multiplication.java
public class Multiplication implements Operation {
@Override
public int apply(int a, int b) {
return a\*b;
}
}
除法實(shí)現(xiàn)Division.java
public class Division implements Operation {
@Override
public int apply(int a, int b) {
return a / b;
}
}
求余實(shí)現(xiàn)Modulo.java
public class Modulo implements Operation {
@Override
public int apply(int a, int b) {
return a % b;
}
}
工廠類OperatorFactory.java
import java.util.HashMap;
import java.util.Map;
import java.util.Optional;
public class OperatorFactory {
static Map<String, Operation> operationMap = new HashMap<>();
static {
operationMap.put("add", new Addition());
operationMap.put("divide", new Division());
operationMap.put("multiply", new Multiplication());
operationMap.put("subtract", new Subtraction());
operationMap.put("modulo", new Modulo());
}
public static Optional<Operation> getOperation(String operation) {
return Optional.ofNullable(operationMap.get(operation));
}
}
使用示例
public int calculateUsingFactory(int a, int b, String operator) {
Operation targetOperation = OperatorFactory
.getOperation(operator)
.orElseThrow(() -> new IllegalArgumentException("Invalid Operator"));
return targetOperation.apply(a, b);
}
3.2 枚舉方式重構(gòu)
枚舉實(shí)現(xiàn)Operator.java
public enum Operator {
ADD {
@Override
public int apply(int a, int b) {
return a + b;
}
},
MULTIPLY {
@Override
public int apply(int a, int b) {
return a * b;
}
},
SUBTRACT {
@Override
public int apply(int a, int b) {
return a - b;
}
},
DIVIDE {
@Override
public int apply(int a, int b) {
return a / b;
}
},
MODULO {
@Override
public int apply(int a, int b) {
return a % b;
}
};
public abstract int apply(int a, int b);
}
封裝Operator到Calculator.java
public int calculate(int a, int b, Operator operator) {
return operator.apply(a, b);
}
使用示例
@Test
public void whenCalculateUsingEnumOperator_thenReturnCorrectResult() {
Calculator calculator = new Calculator();
int result = calculator.calculate(3, 4, Operator.valueOf("ADD"));
assertEquals(7, result);
}
3.3 命令模式
抽象的接口
public interface Command {
Integer execute();
}
實(shí)現(xiàn)類
package com.baeldung.reducingIfElse;
public class AddCommand implements Command {
private int a;
private int b;
public AddCommand(int a, int b) {
this.a = a;
this.b = b;
}
@Override
public Integer execute() {
return a + b;
}
}
其它略
包裝
public int calculate(Command command) {
return command.execute();
}
測試demo
@Test
public void whenCalculateUsingCommand_thenReturnCorrectResult() {
Calculator calculator = new Calculator();
int result = calculator.calculate(new AddCommand(3, 7));
assertEquals(10, result);
}
3.4 規(guī)則引擎重構(gòu)
抽象規(guī)則
public interface Rule {
boolean evaluate(Expression expression);
Result getResult();
}
實(shí)現(xiàn)規(guī)則AddRule.java 其它略
public class AddRule implements Rule {
private int result;
@Override
public boolean evaluate(Expression expression) {
boolean evalResult = false;
if (expression.getOperator() == Operator.ADD) {
this.result = expression.getX() + expression.getY();
evalResult = true;
}
return evalResult;
}
@Override
public Result getResult() {
return new Result(result);
}
}
其中:返回結(jié)果
public class Result {
int value;
public Result(int value) {
this.value = value;
}
public int getValue() {
return value;
}
}
表達(dá)式
public class Expression {
private Integer x;
private Integer y;
private Operator operator;
public Expression(Integer x, Integer y, Operator operator) {
this.x = x;
this.y = y;
this.operator = operator;
}
public Integer getX() {
return x;
}
public Integer getY() {
return y;
}
public Operator getOperator() {
return operator;
}
}
規(guī)則引擎RuleEngine.java
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;
import java.util.stream.Collectors;
public class RuleEngine {
private static List<Rule> rules = new ArrayList<>();
static {
rules.add(new AddRule());
}
public Result process(Expression expression) {
Rule rule = rules.stream()
.filter(r -> r.evaluate(expression))
.findFirst()
.orElseThrow(() -> new IllegalArgumentException("Expression does not matches any Rule"));
return rule.getResult();
}
}
測試demo
@Test
public void whenNumbersGivenToRuleEngine_thenReturnCorrectResult() {
Expression expression = new Expression(5, 5, Operator.ADD);
RuleEngine engine = new RuleEngine();
Result result = engine.process(expression);
assertNotNull(result);
assertEquals(10, result.getValue());
}
4.比較
| 重構(gòu)方式 | SRP | OCP | DIP | LSP | LD | CARP |
|---|---|---|---|---|---|---|
| IF/ELSE | N | N | N | N | N | N |
| 工廠方法 | Y | Y | Y | Y | Y | Y |
| 枚舉方法 | N | Y | Y | Y | Y | Y |
| 命令模式 | Y | Y | Y | Y | Y | Y |
| 規(guī)則引擎 | Y | Y | Y | Y | Y | Y |
5.小結(jié)
為了更好的代碼重用性,可讀性,可靠性,可維護(hù)性,我們會嘗試將IF/ELSE或者case-switch進(jìn)行改造,使用工廠方法,枚舉方法,命令模式,規(guī)則引擎方式不同方法進(jìn)行嘗試,最后使用設(shè)計模式的六大原則對代碼進(jìn)行評估。
到此這篇關(guān)于java如何消除太多的if else判斷的文章就介紹到這了,更多相關(guān)java if else 判斷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解Java編程中if...else語句的嵌套寫法
- Java利用策略模式優(yōu)化過多if else代碼
- Java中if...else語句使用的學(xué)習(xí)教程
- Java的Struts框架中的if/else標(biāo)簽使用詳解
- 聊聊java中一些減少if else 的編碼習(xí)慣的方法
- Java編程細(xì)節(jié)重構(gòu)之為什么if-else不是好代碼詳析
- Java基礎(chǔ)教程_判斷語句if else
- java的if else語句入門指南(推薦)
- 如何優(yōu)雅的替換掉Java代碼中的if else
- Java如何利用狀態(tài)模式(state pattern)替代if else
相關(guān)文章
Mybatis-plus如何通過反射實(shí)現(xiàn)動態(tài)排序不同字段功能
這篇文章主要介紹了Mybatis-plus如何通過反射實(shí)現(xiàn)動態(tài)排序不同字段功能,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02
淺談Java內(nèi)存模型之happens-before
于存在線程本地內(nèi)存和主內(nèi)存的原因,再加上重排序,會導(dǎo)致多線程環(huán)境下存在可見性的問題。那么我們正確使用同步、鎖的情況下,線程A修改了變量a何時對線程B可見?下面小編來簡單介紹下2019-05-05
關(guān)于String.format()格式化輸出方式
String.format()是Java的格式化輸出方法,支持多種數(shù)據(jù)類型和格式化選項,它在格式化和拼接字符串時具有較高的靈活性,但效率相對較低,特別是在處理大量數(shù)據(jù)時,在實(shí)際編程中,應(yīng)根據(jù)具體需求選擇合適的字符串拼接方式2024-12-12
基于Java實(shí)現(xiàn)計數(shù)排序,桶排序和基數(shù)排序
這篇文章主要為大家詳細(xì)介紹了計數(shù)排序,桶排序和基數(shù)排序的多種語言的實(shí)現(xiàn)(JavaScript、Python、Go語言、Java),感興趣的小伙伴可以了解一下2022-12-12
Java ConcurrentModificationException異常解決案例詳解
這篇文章主要介紹了Java ConcurrentModificationException異常解決案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09

