本文,以数据库操作为例子说明
代码:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.StringUtils;
import java.util.ArrayList;
import java.util.List;
/**
* @author Panda
* @create 2019-04-16
*/
public class Demo {
private Logger logger = LoggerFactory.getLogger(this.getClass());
@Autowired
DemoDao demoDao
public List<String> demo(String sqlKey) {
//入参合法性检查
if (!StringUtils.hasText(sqlKey)) {
logger.error("查询请求参数不合法");
return null;
}
//执行sql操作
List<String> list = demoDao.findListBySqlKey(sqlKey);
//判断返回结果集list
if (null == list || list.isEmpty()) {
logger.error("使用sqlKey :{} 数据库查询结果集为空", sqlKey);
//这一步是防止返回的结果集为null,假设调用你接口的用于前端页面展示呢
return new ArrayList<>();
}
return list;
}
}
入参检查好处:
-
StringUtils.hasText(字符串):
-
作用:如果字符串里面的值为null, "", " ", 那么返回值为false; 否则为true
-
结果集检查的好处:
当调用demoDao.findListBySqlKey(sqlKey),返回后,先进行判空,再进行判断集合中是否有元素,若直接判断 if (list.isEmpty()),有可能会发生空指针异常,即 throw new NullPointerException(""),假设公司业务上线,·········
并且上述demo是精简的,在正常的公司业务代码中,大多数会对取出的list数据进行处理,这时候必定会调用list类方法,若上述没有判空,这才是最恐怖的,不过相信大多数人应该会写单元测试O(∩_∩)O哈哈~
仓猝编写,继续上班,若还有好的编程经验,欢迎评论,一起学习。