? ? ? ? 最近在做一个联动列表功能的时候,遇到一个非常奇怪的错误。刚点进去页面就会卡住假死。看了代码感觉没啥问题。然后一步步排查。
? ? ? ?首先我以为是数据量比较大,把页面卡住了。打印出从服务器取得的json字串发现不是很多。
? ? ? ?然后注掉取数据代码,从本地模拟数据加载,发现没问题。这好奇怪。
? ? ? ?我又把adapter的notifyDataSetChanged放到handler去执行,结果还是不行。。
? ? ? ?控制台一直没有错误信息。。。
? ? ? ?后来发现一个打印信息,原来公司使用了一个自己的统计工具(类似友盟),所以我的异常信息都被拦截了,没有打印到控制台。查看工具的打印信息,里面有个gson的错误,
java.lang.ClassCastException: com.google.gson.internal.LinkedTreeMap cannot be cast to cn.XXX.XXX.sale.bean.SubCategory
?
? ? ? 说明在json转换成集合的时候报错了。我的分类实体里有一个子类集合的属性。我在声明的时候?private List subCategoryList;
只这样是不行的!?private List<SubCategory> subCategoryList;就可以完美转换了!
另附gson转换代码
List<Category> tmp = gson.fromJson(categorrStr, new TypeToken<List<Category>>(){}.getType());
?
原文:http://fly-ccy.iteye.com/blog/2188060