- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我得到了自定义对象 MyList 的 ArrayList。 MyList 是 HashMap。 MyList 包含自定义对象 MyListElement 的 ArrayList(它也是 HashMap)。在 GSON 序列化之后它看起来像这样(为了更好的视觉稍微正确一点):
{
"list buyed list": [],
"list name": "item1",
"list quantity": "Не купленных: 0",
"list main list": [
{
"listelement quantity": 4.0,
"listelement sum": 1.0,
"listelement name": "item 1"
},
{
"listelement quantity": 2.0,
"listelement sum": 2.0,
"listelement name": "item 2"
},
{
"listelement quantity": 4.0,
"listelement sum": 3.0,
"listelement name": "item 3"
}
]
},
{
"list buyed list": [],
"list name": "item2",
"list quantity": "Не купленных: 0",
"list main list": [
{
"listelement quantity": 5.0,
"listelement sum": 1.0,
"listelement name": "item 4"
},
{
"listelement quantity": 4.0,
"listelement sum": 7.0,
"listelement name": "item 5"
},
{
"listelement quantity": 6.0,
"listelement sum": 3.0,
"listelement name": "item 6"
}
]
}
但是如果我尝试反序列化它 - 我得到错误:
java.lang.ClassCastException: com.google.gson.internal.LinkedTreeMap cannot be cast to com.llaerto.mysecondbuylist.MyList.
我的反序列化代码:
public void gsonGetFromSerialize() {
String json = "";
try {
FileReader fileReader = new FileReader(this.getFilesDir().getAbsolutePath() + "/mydb.json");
BufferedReader reader = new BufferedReader(fileReader);
String line;
while ((line = reader.readLine()) != null) {
json = json + line + "\n";
}
Log.d("TAG", json);
fileReader.close();
reader.close();
} catch (IOException e) {
e.printStackTrace();
}
Type listType = new TypeToken<ArrayList<MyList>>() {}.getType();
list = new Gson().fromJson(json, listType);
}
抱歉语言和虚拟问题。感谢您的帮助。
MyList类代码:
public class MyList extends HashMap<String, Object> implements Serializable{
public static final String LIST_NAME = "list name";
public static final String LIST_LIST_MAIN = "list main list";
public static final String LIST_LIST_BUYED = "list buyed list";
public static final String LIST_QUANTITY = "list quantity";
public MyList(String name) {
this.put(LIST_NAME, name);
this.put(LIST_LIST_MAIN, new ArrayList<MyListElement>());
this.put(LIST_LIST_BUYED, new ArrayList<MyListElement>());
this.put(LIST_QUANTITY, "Не купленных: " + 0);
}
@Override
public String toString() {
return (String) this.get(LIST_NAME);
}
public void getSum() {
int i = ((ArrayList) this.get(LIST_LIST_MAIN)).size();
this.put(LIST_QUANTITY, "Не купленных: " + i);
}
public String getName() {
return this.get(LIST_NAME).toString();
}
public void setName(String name) {
this.put(LIST_NAME, name);
}
public void toListAdd(MyListElement element) {
ArrayList<MyListElement> list;
list = (ArrayList<MyListElement>) this.get(LIST_LIST_MAIN);
list.add(element);
this.put(LIST_LIST_MAIN, list);
}
}
MyListElement类代码:
public class MyListElement extends HashMap<String, Object> implements Serializable {
public static final String LIST_ELEMENT_NAME = "listelement name";
public static final String LIST_ELEMENT_QUANTITY = "listelement quantity";
public static final String LIST_ELEMENT_COLOR = "listelement color";
public static final String LIST_ELEMENT_SUM = "listelement sum";
public MyListElement(String name, float quantity, float sum) {
this.put(LIST_ELEMENT_NAME, name);
this.put(LIST_ELEMENT_QUANTITY, quantity);
this.put(LIST_ELEMENT_SUM, sum);
//this.put(LIST_ELEMENT_COLOR, color);
}
}
抱歉,我第一次发布时没有。
最佳答案
我没有看到使用 Map 来表示 json 有任何好处,也不明白为什么要那样使用它。恕我直言,使用类会更好理解。所以请把这个答案作为一个建议。我希望将来有人会使用它。
首先你需要创建你的根类。让我们称之为RootItem
.你的 Json 是(实际上看起来像)RootItem
的数组.
public class RootItem {
@SerializedName("list buyed list")
private Collection<String> listBuyedList;
@SerializedName("list name")
private String listName;
@SerializedName("list quantity")
private String listQuality;
@SerializedName("list main list")
private Collection<MainListItem> listMainList;
// Getters & Setters
}
你的 RootItem
类有自己的数组。第一个看起来像一个字符串数组。最后一个是对象数组。让我们称这个对象为MainListItem
.
import com.google.gson.annotations.SerializedName;
public class MainListItem {
@SerializedName("listelement quantity")
private Integer listElementQuantity;
@SerializedName("listelement sum")
private Integer listElementSum;
@SerializedName("listelement name")
private String listElementName;
// Getters & Setters
}
最后,您需要将 JSON 文件解析为 Collection<RootItem>
因为它是 RootItem
的数组对象。
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.reflect.TypeToken;
import java.util.Collection;
public class GsonApp {
private static final String TEST_JSON = "[\n" +
" {\n" +
" \"list buyed list\": [],\n" +
" \"list name\": \"item1\",\n" +
" \"list quantity\": \"Не купленных: 0\",\n" +
" \"list main list\": [\n" +
" {\n" +
" \"listelement quantity\": 4,\n" +
" \"listelement sum\": 1,\n" +
" \"listelement name\": \"item 1\"\n" +
" },\n" +
" {\n" +
" \"listelement quantity\": 2,\n" +
" \"listelement sum\": 2,\n" +
" \"listelement name\": \"item 2\"\n" +
" },\n" +
" {\n" +
" \"listelement quantity\": 4,\n" +
" \"listelement sum\": 3,\n" +
" \"listelement name\": \"item 3\"\n" +
" }\n" +
" ]\n" +
" },\n" +
" {\n" +
" \"list buyed list\": [],\n" +
" \"list name\": \"item2\",\n" +
" \"list quantity\": \"Не купленных: 0\",\n" +
" \"list main list\": [\n" +
" {\n" +
" \"listelement quantity\": 5,\n" +
" \"listelement sum\": 1,\n" +
" \"listelement name\": \"item 4\"\n" +
" },\n" +
" {\n" +
" \"listelement quantity\": 4,\n" +
" \"listelement sum\": 7,\n" +
" \"listelement name\": \"item 5\"\n" +
" },\n" +
" {\n" +
" \"listelement quantity\": 6,\n" +
" \"listelement sum\": 3,\n" +
" \"listelement name\": \"item 6\"\n" +
" }\n" +
" ]\n" +
" }\n" +
"]";
public static void main(String[] args) throws Exception {
final Gson gson = new GsonBuilder().create();
final Collection<RootItem> rootItems = gson.fromJson(TEST_JSON, new TypeToken<Collection<RootItem>>() {
}.getType());
System.out.println(rootItems);
}
}
如果你真的想处理 map 。你可以这样做。
让我们再次创建一个根类并将其命名为RootClass
.
public class RootClass implements Map<String, Object> {
private transient Map<String, Object> inner;
public RootClass() {
this.inner = new HashMap<>();
}
public Collection<Map<String, Object>> getMainListElement(){
final Object object = this.inner.get("list main list");
return object == null ? null : (Collection<Map<String, Object>>)object;
}
// Delegated methods
@Override
public int size() {
return inner.size();
}
@Override
public boolean isEmpty() {
return inner.isEmpty();
}
@Override
public boolean containsKey(Object key) {
return inner.containsKey(key);
}
@Override
public boolean containsValue(Object value) {
return inner.containsValue(value);
}
@Override
public Object get(Object key) {
return inner.get(key);
}
@Override
public Object put(String key, Object value) {
return inner.put(key, value);
}
@Override
public Object remove(Object key) {
return inner.remove(key);
}
@Override
public void putAll(Map<? extends String, ?> m) {
inner.putAll(m);
}
@Override
public void clear() {
inner.clear();
}
@Override
public Set<String> keySet() {
return inner.keySet();
}
@Override
public Collection<Object> values() {
return inner.values();
}
@Override
public Set<Entry<String, Object>> entrySet() {
return inner.entrySet();
}
@Override
public boolean equals(Object o) {
return inner.equals(o);
}
@Override
public int hashCode() {
return inner.hashCode();
}
@Override
public Object getOrDefault(Object key, Object defaultValue) {
return inner.getOrDefault(key, defaultValue);
}
@Override
public void forEach(BiConsumer<? super String, ? super Object> action) {
inner.forEach(action);
}
@Override
public void replaceAll(BiFunction<? super String, ? super Object, ?> function) {
inner.replaceAll(function);
}
@Override
public Object putIfAbsent(String key, Object value) {
return inner.putIfAbsent(key, value);
}
@Override
public boolean remove(Object key, Object value) {
return inner.remove(key, value);
}
@Override
public boolean replace(String key, Object oldValue, Object newValue) {
return inner.replace(key, oldValue, newValue);
}
@Override
public Object replace(String key, Object value) {
return inner.replace(key, value);
}
@Override
public Object computeIfAbsent(String key, Function<? super String, ?> mappingFunction) {
return inner.computeIfAbsent(key, mappingFunction);
}
@Override
public Object computeIfPresent(String key, BiFunction<? super String, ? super Object, ?> remappingFunction) {
return inner.computeIfPresent(key, remappingFunction);
}
@Override
public Object compute(String key, BiFunction<? super String, ? super Object, ?> remappingFunction) {
return inner.compute(key, remappingFunction);
}
@Override
public Object merge(String key, Object value, BiFunction<? super Object, ? super Object, ?> remappingFunction) {
return inner.merge(key, value, remappingFunction);
}
}
但是您的 json 仍然是一个 Collection,因此我们需要使用 Collection 将数据获取到我们的 map 。
public static void main(String[] args) throws Exception {
final Gson gson = new GsonBuilder().create();
final Collection<RootClass> items = gson.fromJson(TEST_JSON, new TypeToken<Collection<RootClass>>() {
}.getType());
System.out.println(items);
}
关于java - JSON 反序列化、GSON、android、错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31299411/
我试图让 gson 在 java 项目上工作,但每次运行时都会出现上述错误。我没有使用任何闪存 IDE,只是 vim,我看到的与我的问题相关的每个问题都与 eclipse 及其部署设置有关。我希望有人
我一直在关注将对象数组转换为 JSON 的教程,但我遇到了一些找不到解决方案的错误。 代码 第 60 - 64 行 Gson gson = new Gson().toJson(data); respo
我正在创建一个新的 Netty 管道,我正在尝试: 避免过早优化。 编写易于向我的一位实习生解释的代码。 这种工厂方法当然很容易解释: public String toJSON() { Gso
我尝试在程序中使用 Unirest,但不断收到此错误 java.lang.NoSuchMethodError: com.google.gson.Gson.newBuilder()Lcom/google
// Retrofit compile 'com.squareup.retrofit2:retrofit:2.1.0' // JSON Parsing compile 'com.google.code
我正在尝试将 Gson 与接口(interface)一起使用: public interface Photo { public int getWidth(); } public class D
我正在执行一个 Web 服务,这是我的响应,但是当我尝试使用 Gson 库将此 JSONObject(org.json.JSONObject) 转换为特定对象时,我的应用程序崩溃了。所以,我不知道为什
我有以下 .json 文件 - { "IDs":[ "1716136233", "2030187302", "204897807
我试图在我的项目中使用 GSON,但我的应用程序崩溃了,logcat 说找不到 com.google.gson.Gson。我已将 import com.google.gson.Gson 放在我的类文件
在下面的示例中,我尝试序列化我的自定义类Couple,其中包含Point2D 类型的字段。 我发现,SErialzing 的过程取决于 DEserializer 的存在。 此外,如果存在反序列化器,则
我有课 class ThreadComment( banned: Int, closed: Int, comment: String?, date: String?,
使用 gson 解析 json 时,我有一个奇怪的行为。我使用这个代码: private static Container parseContainer(String containerJson) {
我注意到 GSON HTML 转义 字符,可以通过使用disableHtmlEscaping()来禁用它构建器配置方法。但我的问题是 - 为什么 GSON 默认情况下会进行 HTML 转义?不进行 H
我注意到一个奇怪的问题。我可以使用 Junit 运行我的测试用例,但是当我使用 maven 运行时,其中一个测试用例失败。它提示找不到 Gson 类 def。 我能够在 Maven 依赖项中看到 Gs
我有一个看起来像这样的 json {response:{"status":{"....."},data:[{"name":"Alice","id":"123"},{"name":"Jack","id"
所以,我的应用已经发布了将近一年,但没有看到这个问题,现在它出现了。 即使是现在,我的手机上的调试版本也没有这个问题。我对从 Android Studio 打开的任何模拟器没有任何问题。然而,Goog
我是 Android 开发环境的新手,因此需要专家的帮助。 java.lang.NoClassDefFoundError: com.google.gson.Gson 项目中包含 Gson 库,但是当从
总结 我在我的 android 应用程序中使用 Retrofit 和 Gson 有一段时间了,但是我从服务器获得的 ID 是 13 位数字。 Gson 自动将这些数字转换为科学计数法,然后将其转换为
我正在使用一个大的 JSON 对象,它具有来自多个请求的响应。 我正在处理的部分只需要很少的对象,而且它们并不总是在前面。例如 json 结构是: ** json = { mainDocume
我有一个休息网络服务: @Path("/tranreq") public class TranscriptRequesterResource { private static final Gs
我是一名优秀的程序员,十分优秀!