当我们谈论序列化时,实际上是在讨论如何把一个对象转换成一种持久化或可传输的形式。这个过程需要把对象的状态信息写入某种能够存储或传输的方式,以后能够重新创建这个对象
对于解析JSON字符串也有序列化和反序列化:
为什么要实现?
因为它让对象可以被保存更久,甚至可以在网络上传输。所以,所有需要网络传输或长期保存的对象都必须是可序列化的。举个例子,像在不同的计算机之间调用函数(RMI)或者在 Android 不同进程间传递对象,都需要序列化
在 Java 中,序列化是通过实现 Serializable
接口来完成的。在这个过程中,我们还可以定义一个版本号,这个版本号能帮助确定对象的状态是否匹配,这在反序列化时尤为重要
常用的序列化:
@Override
public List<User> findUserByTags(List<String> list) {
// 首先判断list是否为空
if (CollectionUtils.isEmpty(list)) {
throw new BusinessException(ErrorCode.NULL_ERROR);
}
// 先查询出所有用户
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
List<User> userList = userMapper.selectList(queryWrapper);
Gson gson = new Gson(); // 序列化对象
return userList.stream().filter(user -> {
String tags = user.getTags();
if (StringUtils.isBlank(tags)) {
return false;
}
/**
*TypeToken<Set<String>>() 则是 Gson 库中用于表示泛型类型的一种方式
* 在这里就是将数据库的对象序列化成java对象了
*/
Set<String> TagNameSet = gson.fromJson(tags, new TypeToken<Set<String>>() {
}.getType());
for (String t : list) {
if (!TagNameSet.contains(t)) {
return false;
}
}
return true;
}).map(this::getSafetyUser).collect(Collectors.toList());
}
```