java 如何判断encode_java如何消除太多的if else判断?

6e9e82ade1860cfbc6bf920b1bf4db2d.png

1.简介

if判断语句是很多编程语言的重要组成部分。但是,若我们最终编写了大量嵌套的if语句,这将使得我们的代码更加复杂和难以维护。

让我们看看能否使用别的方式来做呢。

设计模式是为了更好的代码重用性,可读性,可靠性,可维护性,它有六大原则

1)单一职责原则(Single Responsibility Principle,简称SRP):该原则是针对类来说的,即一个类应该只负责一项职责.

2)开放--封闭原则(The Open-Closed Principle简称OCP):是说软件实体(类、模块、函数等等)应该可以扩展,但是不可以修改。

3)依赖倒转原则(Dependence Inversion Principle :针对接口编程,不要对实现编程

4)里氏代换原则(Liskov Substitution Principle,简称LSP):里氏代换原则,子类型必须能够替换掉他们的父类型

5)迪米特法则(Law of Demeter):如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用

6)合成/聚合复用原则(Composition/Aggregation Principle],简称CARP):尽量使用合成/聚合,尽量不使用类继承。合成聚合是“has a”的关系,而继承是“is a”的关系。

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; }

case-switch

 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.重构

3.1 工厂方式重构

抽象层Operation.java

public interface Operation { int apply(int a, int b);}

加法实现Addition.java:

public class Addition implements Operation { @Override public int apply(int a, int b) { return a + b; }}

减法实现Subtraction.java

public class Subtraction implements Operation { @Override public int apply(int a, int b) { return a - b; }}

乘法实现Multiplication.java

public class Multiplication implements Operation { @Override public int apply(int a, int b) { return a*b; }}

除法实现Division.java

public class Division implements Operation { @Override public int apply(int a, int b) { return a / b; }}

求余实现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 operationMap = new HashMap<>(); static { operationMap.put("add
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值