优化以下代码public <T> T parseObject(Object obj, Class<T> tClass) { // 如果是dubbo创建的代理类,则无法通过简单的方式进行序列化 if (Proxy.isProxyClass(obj.getClass())) { // 打印对象类型 log.info("检测到代理对象,对象类型为:{}", obj.getClass().getName()); // 获取调用句柄 InvocationHandler invocationHandler = Proxy.getInvocationHandler(obj); // 脱壳处理,获取其代理对象 其为dubbo的PojoUtils里面的一个私有内部类 Object realize = PojoUtils.realize(invocationHandler, null); try { // 获取内部类中的参数 map Field map = realize.getClass().getDeclaredField("map"); // 设置权限 map.setAccessible(true); // 获取该map值 即为需要序列化的一个对象 obj = map.get(realize); } catch (Exception e) { // 此处往往为 获取对应的内容失败 即获取到的代理对象并非dubbo对应的代理对象 log.error("序列化失败,异常信息为:{}", ExceptionUtils.getStackTrace(e)); throw new OdcBizException(OdcResultCodeEnum.SERIALIZE_ERROR); } } // 如果非代理类 则直接序列化后 转换为对应的实体类 并返回 return JSON.parseObject(JSON.toJSONString(obj), tClass); }
时间: 2023-05-19 12:06:52 浏览: 116
这段代码是一个泛型方法,用于将一个对象序列化为指定的实体类对象。如果传入的对象是dubbo创建的代理类,则需要进行特殊处理,通过脱壳获取其代理对象,并从中获取需要序列化的对象。如果传入的对象不是代理类,则直接进行序列化并转换为对应的实体类对象。
相关问题
下面是使用fastjson写的代码` private <T> List<T> getArray(Object obj,Class<T> clazz){ String s = getJSONString(obj); return JSON.parseArray(s,clazz); } public <T> T getData(TypeReference<T> tTypeReference) { String s = this.getJSONString(this.getData()); return JSON.parseObject(s,tTypeReference); }`请将这个代码转为使用jsckson的
下面是使用jackson写的代码:
```
private <T> List<T> getArray(Object obj, Class<T> clazz) {
String s = getJSONString(obj);
ObjectMapper mapper = new ObjectMapper();
try {
return mapper.readValue(s, mapper.getTypeFactory().constructCollectionType(List.class, clazz));
} catch (JsonProcessingException e) {
e.printStackTrace();
}
return null;
}
public <T> T getData(TypeReference<T> tTypeReference) {
String s = this.getJSONString(this.getData());
ObjectMapper mapper = new ObjectMapper();
try {
return mapper.readValue(s, tTypeReference);
} catch (JsonProcessingException e) {
e.printStackTrace();
}
return null;
}
```
需要注意的是,在 jackson 中,需要使用 `ObjectMapper` 对象来进行 JSON 解析,在解析 List 类型时,需要使用 `constructCollectionType` 方法来构造 List 类型的 TypeReference。
public class test<T> { public <T super Number> void printObj(T num) { System.out.println(num); } }为什么报错?如何修改
这段代码报错的原因是 `<T super Number>` 这个语法不正确,应该使用 `<? super Number>`。
正确的代码如下:
```
public class test<T> {
public void printObj(T num) {
System.out.println(num);
}
public void printNumList(List<? super Number> numList) {
System.out.println(numList);
}
}
```
在泛型方法中使用 `<? super Number>` 表示参数类型必须是 Number 类型或其父类类型,这样就可以正确编译通过。
阅读全文