package xcc.mapTest;

/**
* @Decription: 接口
* @Author:
* @Date:
* @Email:
**/
public interface Function { /**
* 要做的事情
*/
void invoke();
}
package xcc.mapTest;

import java.util.Map;

/**
* @Decription: 代替'if else' 和 'switch'的方法
* @Author:
* @Date:
* @Email:
**/
public class IfFunction<K> { private Map<K, Function> map; /**
* 通过map类型来保存对应的条件key和方法
*
* @param map a map
*/
public IfFunction(Map<K, Function> map) {
this.map = map;
} /**
* 添加条件
*
* @param key 需要验证的条件(key)
* @param function 要执行的方法
* @return this.
*/
public IfFunction<K> add(K key, Function function) {
this.map.put(key, function);
return this;
} /**
* 确定key是否存在,如果存在,则执行相应的方法。
*
* @param key the key need to verify
*/
public void doIf(K key) {
if (this.map.containsKey(key)) {
map.get(key).invoke();
}
} /**
* 确定key是否存在,如果存在,则执行相应的方法。
* 否则将执行默认方法
*
* @param key 需要验证的条件(key)
* @param defaultFunction 要执行的方法
*/
public void doIfWithDefault(K key, Function defaultFunction) {
if (this.map.containsKey(key)) {
map.get(key).invoke();
} else {
defaultFunction.invoke();
}
} }
package xcc.mapTest;

import java.util.HashMap;

public class Test3 {
public static void main(String[] args) {
IfFunction<String> ifFunction = new IfFunction<>(new HashMap<>(5)); //定义好要判断的条件和对应执行的方法
ifFunction.add("1", () -> System.out.println("苹果"))
.add("2", () -> System.out.println("西瓜"))
.add("3", () -> System.out.println("橙子")); //要进入的条件
ifFunction.doIf("2");
}
}

最新文章

  1. thinkphp添加数据
  2. Nhibernate Query By Criteria 条件查询
  3. binary-tree-maximum-path-sum(mock)
  4. jquery 预览提交的表单
  5. 8个必备的PHP功能开发
  6. HTML5 FileAPI读取实例---(一)
  7. 初学Pexpect
  8. 关于js中的类型内容总结(类型识别)
  9. Augular JS里的各种ng
  10. freeSSHD在windows环境下搭建SFTP服务器
  11. html页面打开ie浏览器默认打开最高版本
  12. 【原创】Linux基础之vi
  13. MySQL数据库SQL语句基本操作
  14. vue.js中axios的封装
  15. 【神经网络】Dependency Parsing的两种解决方案
  16. 移动网页广告引入mraid.js使用指南
  17. 加入EOS主网
  18. eclipse自定义工具栏
  19. WEB框架Django之Form组件
  20. [数据结构]最小生成树算法Prim和Kruskal算法

热门文章

  1. Windows10系统,截图黑屏,怎么办?
  2. 如何消灭飞机的“黑色十分钟”,AI来帮忙
  3. C语言中的 “&gt;&gt;”与“&lt;&lt;”
  4. break statement not within loop or switch报错
  5. 总结HashMap实现原理分析
  6. jieba.lcut方法
  7. hashlib加密算法
  8. 数据结构C语言实现----直接插入排序
  9. luogu P2525 Uim的情人节礼物 其之壱
  10. .Net Core 实体生成器