开发问题并不是经常遇到的,有技术问题,也有业务问题,记录一下,以备不时之需。
将B类型的对象封装成A类型的对象,常用于Map对象封装成Entity对象,这里有Gson和JSON两种方式:
A_Class a_Object = new Gson().fromJson(new Gson().toJson(B_Object), A.class);
A_Class a_Object = JSON.parseObject(JSON.toJSONString(B_Object),A.class);
异常 :one:
com.alibaba.fastjson.JSONException: syntax error, expect {, actual string, pos 0, fastjson-version 1.2.70
List<B_Object> b_Object_List= JSON.parseArray(strObject, B_Object.class);
排序问题是很常见的,我们可以在数据库进行排序,给每个值一个排序的量,但是有的时候,我们的排序只能在后台进行处理,这个时候,我们就需要一个固定的排序模板了。
public class SortMethod {
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<String> getFixedSortList(String fixedSortSchemaStr, String disorderedStr) {
// 用于去重
Set<String> 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;
}
}
ArrayList允许添加null值,就容易造成了list内的对象转换出现java.lang.NullPointerException异常。
场景举例:
List<User> 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了。
这个问题出现的原因不详,但是解决的办法是有的:
<dependency>
<groupId>com.sun</groupId>
<artifactId>tools</artifactId>
<version>1.8.0</version>
<scope>system</scope>
<!-- 这个位置按照实际情况填写 -->
<systemPath>E:\Jdk\jdk1.8.0_161\lib/tools.jar</systemPath>
</dependency>
总结: 空指针异常是老生常谈的问题,造成空指针的情况非常多,在实际开发过程中要有意识的考虑null值问题。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。