实战if-else 过多详解
1.本文实例代码仅仅是俩个小例子。
package com.example.demo.pattern.ifElse; import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.function.Consumer;
import java.util.function.Function; /**
* 如何解决解决类似
* 1 if (condition1) {
* 2
* 3 } else if (condition2) {
* 4
* 5 } else if (condition3) {
* 6
* 7 } else if (condition4) {
* 8
* 9 } else {
* 10
* 11 }
*
* 1 if (param.equals(value1)) {
* 2 doAction1(someParams);
* 3 } else if (param.equals(value2)) {
* 4 doAction2(someParams);
* 5 } else if (param.equals(value3)) {
* 6 doAction3(someParams);
* 7 }
* 8
*/
public class SolveIfElseOne {
//定义结构 属于工厂模式 基于java8 lambda
private static final Map<String, Consumer<String>> map=new HashMap<>();
//用LinkedHashMap 是为了保证有序性
private static final Map<Integer, Function<Integer,Double>> map1=new LinkedHashMap<>();
//初始化数据
static{
map.put("1",(param)->{doAction1(param);});
map.put("2",(param)->{doAction2(param);});
map.put("3",(param)->{doAction3(param);}); map1.put(2200,(param)->{return doAction2200(param);});
map1.put(2700,(param)->{return doAction2700(param);});
map1.put(3200,(param)->{return doAction3200(param);});
} /**
* 未重构前
*/
public void handle(String param){
if (param.equals("1")) {
doAction1(param);
} else if (param.equals("2")) {
doAction2(param);
} else if (param.equals("3")) {
doAction3(param);
}
} public static void doAction1(String param){
System.out.println(param);
} public static void doAction2(String param){
System.out.println(param);
} public static void doAction3(String param){
System.out.println(param);
} //未重构前
/* 1 if income <= 2200
2 tax = 0
3 else if income <= 2700
4 tax = 0.14 * (income - 2200)
5 else if income <= 3200
6 tax = 70 + 0.15 * (income - 2700)
7 else if income <= 3700
8 tax = 145 + 0.16 * (income - 3200)
9 ......
10 else
11 tax = 53090 + 0.7 * (income - 102200)*/ public static double doAction2200(int income){
double tax = 0;
return tax = 0;
} public static double doAction2700(int income){
double tax = tax = 0.14 * (income - 2200);
return tax ;
} public static double doAction3200(int income){
double tax = 70 + 0.15 * (income - 2700);
return tax;
} //重构后 只需要循环一次即可
public static double getTax(int income){
double res=0;
for(Integer integer:map1.keySet()){
if(income<=integer) {
System.out.println(integer+" ");
res=map1.get(integer).apply(income);
System.out.println(map1.get(integer).apply(income)+" ");
break;
}
}
return res;
} public static void main(String[] args) {
SolveIfElseOne.map.get("1").accept("1"); System.out.println(getTax(3200)); } }
实战if-else 过多详解的更多相关文章
- Linq实战 之 DataSet操作详解
Linq实战 之 DataSet操作详解 一:linq to Ado.Net 1. linq为什么要扩展ado.net,原因在于给既有代码增加福利.FCL中在ado.net上扩展了一些方法. 简单一 ...
- IdentityServer4实战 - JWT Token Issuer 详解
原文:IdentityServer4实战 - JWT Token Issuer 详解 一.前言 本文为系列补坑之作,拖了许久决定先把坑填完. 下文演示所用代码采用的 IdentityServer4 版 ...
- Java工程师 基础+实战 完整路线图(详解版)
Java工程师 基础+实战 完整路线图(详解版) Java 基础 Java 是一门纯粹的面向对象的编程语言,所以除了基础语法之外,必须得弄懂它的 oop 特性:封装.继承.多态.此外还有泛型.反射 ...
- SpringCloud微服务项目实战 - API网关Gateway详解实现
前面讲过zuul的网关实现,那为什么今天又要讲Spring Cloud Gateway呢?原因很简单.就是Spring Cloud已经放弃Netflix Zuul了.现在Spring Cloud中引用 ...
- SVN与TortoiseSVN实战:文件加锁详解
硬广:<SVN与TortoiseSVN实战>系列已经写了八篇,本篇是完结篇,整个系列结合TortoiseSVN对SVN中容易被忽视的部分进行了详解,以技巧性为主. 本篇详解使用Tortoi ...
- Asp.Net Core 中IdentityServer4 实战之角色授权详解
一.前言 前几篇文章分享了IdentityServer4密码模式的基本授权及自定义授权等方式,最近由于改造一个网关服务,用到了IdentityServer4的授权,改造过程中发现比较适合基于Role角 ...
- maven实战(02)_坐标详解
(一) 何为mave坐标 maven的世界中拥有数量非常巨大的构件,也就是平时用的一些jar,war等文件. maven定义了这样一组规则: 世界上任何一个构件都可以使用Maven坐标唯一标志,ma ...
- ios开发——实战OC篇&FMDB详解
FMDB详解 前一篇文章中我们介绍的SQLite的使用,在iOS中原生的SQLite API在使用上相当不友好. 于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.Plausibl ...
- Jmeter(七) - 从入门到精通 - 建立数据库测试计划实战<MySQL数据库>(详解教程)
1.简介 在实际工作中,我们经常会听到数据库的性能和稳定性等等,这些有时候也需要测试工程师去评估和测试,上一篇文章宏哥主要介绍了jmeter连接和创建数据库测试计划的过程,宏哥在文中通过示例和代码非常 ...
随机推荐
- [组件封装]微信小程序-日历
描述 切换月份, 当天文案为今天, 日期背景变色, 日期红点标识, 点击选中日期. 效果 源码 calendar.wxml <view class="component"&g ...
- Journal of Proteomics Research | Th-MYCN转基因小鼠的定量蛋白质学分析揭示了Aurora Kinase抑制剂改变代谢途径和增强ACADM以抑制神经母细胞瘤的进展
题目:Quantitative Proteomics of Th-MYCN Transgenic Mice Reveals Aurora Kinase Inhibitor Altered Metabo ...
- NeurIPS 2019 | 基于Co-Attention和Co-Excitation的少样本目标检测
论文提出CoAE少样本目标检测算法,该算法使用non-local block来提取目标图片与查询图片间的对应特征,使得RPN网络能够准确的获取对应类别对象的位置,另外使用类似SE block的sque ...
- 性能测试从零开始-LoadRunner入门
写在前面 又到了公司每月的读书会,经过上个月的试运行后,公司把读书会纳入每月的绩效考核中,听到这个消息,当时我的内心是崩溃的,不过从另一方面来讲,对于我来说也一件好事儿,这样可以督促自己养成读书的习惯 ...
- python浅学【网络服务中间件】之MongoDB
一.关于MongoDB: MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供 ...
- 微信小程序api封装
写多 之后,吸取之前的经验,瞎写了一个简单的封装api,有幸看到的朋友,就随便看看哈,如果能给到你帮助就一直棒了,额呵呵呵! 新建constant.js和api.js文件 在constant.js中统 ...
- 金融和IT的区别
在进入金融圈之前, 我写了十五年的代码, 在San Francisco Bay Area(也就是中国人所说的硅谷)工作过两三年. 去年因为Fintech和香港.NET俱乐部的缘故, 我接触了私人银行和 ...
- Asp.Net Core 学习教程2、使用ASP.NET Core中的RazorPages
1.创建一个Asp.Net Core Web应用程序 1.1.打开VS2019 新建项目 1.2.选好项目位置后进入线面界面,选择Web应用程序 1.3.进去的页面结构如下 Pages 文件夹:包含 ...
- NASNet : Google Brain经典作,改造搜索空间,性能全面超越人工网络,继续领跑NAS领域 | CVPR 2018
论文将搜索空间从整体网络转化为卷积单元(cell),再按照设定堆叠成新的网络家族NASNet.不仅降低了搜索的复杂度,从原来的28天缩小到4天,而且搜索出来的结构具有扩展性,在小模型和大模型场景下都能 ...
- UVA129 Krypton Factor 困难的串 dfs回溯【DFS】
Krypton Factor Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ...