com.google.gson.internal.LinkedTreeMap cannot be cast to xxx

本文提供了一个使用Gson进行泛型解析的示例代码,介绍了如何通过传入泛型Class类型实现JSON数据到Java对象的转换,并展示了具体的实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用Gson泛型解析的时候报错

这里贴一个泛型解析的示例

public <T> T getJSONEntryForDetails(Context context, String fileName, Class<T> cls) {
    InputStream inputStream = AssetsHelper.getInstance().openAssets(context, fileName);
    if (inputStream == null) {
        return null;
    }
    T entry = null;
    JsonReader jsonReader = null;
    try {
        InputStreamReader inputStreamReader = new InputStreamReader(inputStream);
        jsonReader = new JsonReader(inputStreamReader);
        entry = GsonUtils.getInstance().getGson().fromJson(jsonReader, cls);
    } finally {
        if (jsonReader != null) {
            try {
                jsonReader.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
    return entry;
}
  • 其中AssetsHelper用于从assets获取json文件
  • 一个是要传入泛型的Class类型,即上面的cls,用于fromJson方法获取对应的目标类型
  • 另一个就是返回类型了


欢迎关注我的公众号,和我一起每天进步一点点!
这里写图片描述

### 解决 `LinkedTreeMap` 无法转换为 `String` 当使用 Gson 进行 JSON 反序列化时,如果目标对象是一个自定义类而非标准集合类,则可能会遇到 `ClassCastException`。具体来说,在尝试将 `com.google.gson.internal.LinkedTreeMap` 转换为其他类(如 `java.lang.String` 或者任何特定业务实体类)时会抛出此异常。 为了防止这种错误发生,可以采取以下几种方法之一: #### 方法一:确保正确指定参数 在调用 `fromJson()` 函数之前,应该通过 `TypeToken` 明确指出期望的结果类。这有助于让 Gson 知道如何构建最终的对象实例而不是默认创建 `LinkedTreeMap` 实例来表示未知类的映射关系[^3]。 ```java // 定义具体的返回类 Type typeOfT = new TypeToken<String>(){}.getType(); String resultStr = gson.fromJson(jsonInput, typeOfT); ``` #### 方法二:处理原始 Map 数据再转为目标类 另一种方式是从 JSON 中先解析得到一个通用的 `Map<String,Object>` 对象,然后再根据实际情况将其进一步加工成为所需的字符串或其他形式的数据结构[^1]。 ```java JsonElement jsonElement = JsonParser.parseString(jsonInput); if (jsonElement.isJsonObject()) { JsonObject jsonObject = jsonElement.getAsJsonObject(); Set<Map.Entry<String, JsonElement>> entries = jsonObject.entrySet(); StringBuilder sb = new StringBuilder(); for (Map.Entry<String, JsonElement> entry : entries) { sb.append(entry.getKey()).append(": ").append(entry.getValue().getAsString()).append("\n"); } String formattedResult = sb.toString(); } ``` #### 方法三:编写自定义反序列化器 对于更复杂的需求,还可以考虑实现自己的 `JsonDeserializer<T>` 接口来自定义反序列化的逻辑流程,从而更好地控制从 JSON 到 Java 对象之间的转换过程[^2]。 ```java public class CustomDeserializer implements JsonDeserializer<String> { @Override public String deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException { // 自定义转换逻辑... return json.getAsString(); } } GsonBuilder builder = new GsonBuilder(); builder.registerTypeAdapter(String.class, new CustomDeserializer()); Gson customGson = builder.create(); customGson.fromJson(jsonInput, String.class); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值