Java【问题记录 02】对象封装+固定排序+list All elements are null引起的异常处理+Missing artifact com

public static void main(String[] args) {
    String disorderedStr = "开封,洛阳,开封,郑州,郑州,洛阳";
    String fixedSortSchemaStr = "郑州,开封,洛阳,平顶山,安阳,鹤壁,新乡,焦作,濮阳,许昌,漯河,三门峡,商丘,周口,驻马店,南阳,信阳,济源";
    List<String> fixedSortList = getFixedSortList(fixedSortSchemaStr, disorderedStr);
    fixedSortList.forEach(System.out::println); // 郑州 开封 洛阳
}

/\*\*

* 实现固定排序
*
* @param fixedSortSchemaStr 用于固定排序的模板
* @param disorderedStr 重复且乱序的字符串
* @return 不重复且按照固定顺序排列的序列
*/
public static List getFixedSortList(String fixedSortSchemaStr, String disorderedStr) {
// 用于去重
Set uniqueness = new HashSet<>();
String[] disordered = disorderedStr.split(“,”);
Collections.addAll(uniqueness, disordered);

    // 用于固定排序
    List<String> fixedSortSchemaList = new ArrayList<>(Arrays.asList(fixedSortSchemaStr.split(",")));
    // 用于存放最终排序结果
    List<String> fixedSortList = new ArrayList<>();
    // 匹配顺序
    for (String item : fixedSortSchemaList) {
        if (uniqueness.contains(item)) {
            fixedSortList.add(item);
        }
    }
    return fixedSortList;
}

}


### 3 list All elements are null 引起的异常


ArrayList允许添加null值,就容易造成了list内的对象转换出现java.lang.NullPointerException异常。


**场景举例:**



List users = useDao.find(xxx);
//size=1,All elements are null


数据库执行的SQL如下,查询出的不是没有记录,而是一条 null,null这样的记录,导致User对象为null,这时候对user对象操作就会报错!



select min(id) as id,min(name) as name from user where 1 = 2;


**解决办法:**


法一:移除null元素【主要用的是 listObject.removeAll(Collections.singleton(null));】



public static void main(String[] args) {
    List<User> users = new ArrayList<User>();
    users.add(null);
    users.add(null);
    users.add(null);
    System.out.println("size:" + users.size()); // size:3
    for (User user : users) {
        try {
            System.out.println("id:" + user.getId() + ",name:" + user.getName());
        } catch (Exception ex) {
            System.out.println(ex); //java.lang.NullPointerException
        }
    }
    users.remove(null); // 移除第一个null
    System.out.println("size:" + users.size()); // size:2
    users.removeAll(Collections.singleton(null)); // 移除所有的null元素
    System.out.println("size:" + users.size()); // size:0
    // 不会进入循环
    for (User user : users) {
        try {
            System.out.println("id:" + user.getId() + ",name:" + user.getName());
        } catch (Exception ex) {
            System.out.println(ex);
        }
    }
}

法二:保证数据库查询出来没有null值,即遇null值转换为默认值【数据库的null值函数要例用起来,会避免很多的 NullPointerException 异常】



– mysql下使用ifnull实现 当然还有其他的空值函数
SELECT
ifnull( min( id ), -1 ) AS id,
ifnull( min( name ), ‘defaultName’ ) AS name
FROM USER WHERE 1 = 2;


这样子查询出来的是 {“id”:-1,“name”:“defaultName”} 就不会再出现NPE了。


### 4 Missing artifact com.sun:tools:jar:1.8.0


这个问题出现的原因不详,但是解决的办法是有的:



com.sun tools 1.8.0 system E:\Jdk\jdk1.8.0_161\lib/tools.jar

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值