日常开发中,经常会使用到根据 if 判断后处理逻辑,如果情况较多,就会出现大量的if-else if- 。。。。使得代码可读性较差
如:
现在使用一种接口+实现的方式,巧妙地解决这种问题。
1.定义一个Handler接口,并加两个方法,一个是用于判断的条件,另一个是处理逻辑的方法
public interface IMessageHandler {
/**
* 根据条件判断是否选择当前handler
* @param isDealParam
* @return
*/
boolean canHandler(String isDealParam);
/**
* 处理主体逻辑
* @param param
* @return
*/
String handler(String param);
}
2.定义需要实现的类,处理逻辑
这里只是使用了两个较简单的例子,只使用了一个值,做了输出,实际开发要复杂的多
// 定义默认的handler
@Component
public class DefaultMessageHandler implements IMessageHandler {
@Override
public boolean canHandler(String isDealParam) {
return ObjectUtil.equal(isDealParam,"default");
}
@Override
public String handler(String param) {
System.out.println("当前处理逻辑的是"+this.getClass());
return param;
}
}
/*****************************另一个类**************************/
// 其他情况处理的handler
@Component
public class CallBackMessageHandler implements IMessageHandler {
@Override
public boolean canHandler(String isDealParam) {
return ObjectUtil.equal(isDealParam,"callback");
}
@Override
public String handler(String param) {
System.out.println("当前处理逻辑的是"+this.getClass());
return param;
}
}
3.调用
@Controller
@RequestMapping("handler")
public class HandlerController {
@Autowired
private List<IMessageHandler> messageHandlers;
/**
*
* 测试
**/
@RequestMapping("testHandler")
public void testHandler(@RequestParam("param") String param){
IMessageHandler handler = messageHandlers.stream()
.filter(messageHandler-> messageHandler.canHandler(param))
.findFirst()
.orElse(new DefaultMessageHandler());
String message = handler.handler(param);
System.out.println(message);
}
}
4.测试
①传参 callback ,控制台输出
当前处理逻辑的是class com.seage.demo.handler.CallBackMessageHandler
callback
②传参非 callback ,控制台输出
当前处理逻辑的是class com.seage.demo.handler.DefaultMessageHandler
default
实际测试情况:
http://localhost:8900/handler/testHandler?param=callback
http://localhost:8900/handler/testHandler?param=default