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