在实际开发过程中,有些代码逻辑是需要表类(通过数据库的表建立的类)之间的关系来实现的。比如一个简单的需求:就是要找到一个客户的所属市场的名字,在我的现有的公司业务上的代码逻辑是:
String mpName=member.getStore().getMarketplace.getName();
当我要判断是否为xx市场,那么在表设计之初或者是添加了一些不标准的数据,在执行性该行代码的时候就会报NPE。那么我们如何在仅有的关系上来改变或者优化代码,即在不改变表数据的情况下,对此优化的方式有哪些?
1.传统的null判断
if(member.getStore()==null){
...
if(store.getMarketplace==null){
...
if(marketplace.getName()==null){
...
}
}
}
2.异常捕获
String mpName="";
try{
mpName=member.getStore().getMarketplace.getName();
}catch(Exception e){
mpName="unknow"
}
3.jdk8的工具类Optional
String mpname=Optional.ofNullable(member)
.map(m->m.getStore())
.map(s->s.getMarketplace())
.map(p->p.getName())
.orElse("unknow");
//.ifPresent(m->m.setName("nuknow"));
orElse和ifPresent的区别是:
orElse:有null就执行
ifPresent:全为null就执行
4.局限的StringUtils三方工具。
这个一般处理请求参数,用的是lang3,开发过程中常用就不多说了。
相对我个人而言,官方推出的工具过程太长,用链式来解决链式比较麻烦,简单一点就是用try...catch..来完成一般的链式逻辑代码。