java如何消除太多的if else判斷示例代碼
1.簡(jiǎn)介
if判斷語句是很多編程語言的重要組成部分。但是,若我們最終編寫了大量嵌套的if語句,這將使得我們的代碼更加復(fù)雜和難以維護(hù)。
讓我們看看能否使用別的方式來做呢。
設(shè)計(jì)模式是為了更好的代碼重用性,可讀性,可靠性,可維護(hù)性,它有六大原則:
- 單一職責(zé)原則(Single Responsibility Principle,簡(jiǎn)稱SRP):該原則是針對(duì)類來說的,即一個(gè)類應(yīng)該只負(fù)責(zé)一項(xiàng)職責(zé).
- 開放--封閉原則(The Open-Closed Principle簡(jiǎn)稱OCP):是說軟件實(shí)體(類、模塊、函數(shù)等等)應(yīng)該可以擴(kuò)展,但是不可以修改。
- 依賴倒轉(zhuǎn)原則(Dependence Inversion Principle :針對(duì)接口編程,不要對(duì)實(shí)現(xiàn)編程
- 里氏代換原則(Liskov Substitution Principle,簡(jiǎn)稱LSP):里氏代換原則,子類型必須能夠替換掉他們的父類型
- 迪米特法則(Law of Demeter):如果兩個(gè)類不必彼此直接通信,那么這兩個(gè)類就不應(yīng)當(dāng)發(fā)生直接的相互作用
- 合成/聚合復(fù)用原則(Composition/Aggregation Principle],簡(jiǎn)稱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(); }
測(cè)試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(); } }
測(cè)試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ù)性,我們會(huì)嘗試將IF/ELSE或者case-switch進(jìn)行改造,使用工廠方法,枚舉方法,命令模式,規(guī)則引擎方式不同方法進(jìn)行嘗試,最后使用設(shè)計(jì)模式的六大原則對(duì)代碼進(jìn)行評(píng)估。
到此這篇關(guān)于java如何消除太多的if else判斷的文章就介紹到這了,更多相關(guān)java if else 判斷內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(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)文章
Java Web項(xiàng)目中編寫定時(shí)任務(wù)的實(shí)現(xiàn)
本篇文章主要介紹了Java Web項(xiàng)目中編寫定時(shí)任務(wù)的實(shí)現(xiàn),具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01Spring Cloud中各組件超時(shí)總結(jié)
在大家學(xué)習(xí)spring cloud的時(shí)候組件是必不可少的一部分,下面這篇文章主要給大家介紹了關(guān)于Spring Cloud中各組件超時(shí)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2017-11-11SpringBoot整合Netty+Websocket實(shí)現(xiàn)消息推送的示例代碼
WebSocket使得客戶端和服務(wù)器之間的數(shù)據(jù)交換變得更加簡(jiǎn)單,允許服務(wù)端主動(dòng)向客戶端推送數(shù)據(jù),本文主要介紹了SpringBoot整合Netty+Websocket實(shí)現(xiàn)消息推送的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01Springboot Cache @CacheEvict 無法模糊刪除的解決方案
這篇文章主要介紹了Springboot Cache @CacheEvict 無法模糊刪除的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12