- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在我的应用程序中,我使用 ActiveAndoid
.
在某些模型中,我有一列 List<String>
和其他List<MyEnum>
.
我创建了一个 TypeSerializer
对于每种类型:
public class StringsListTypeSerializer extends TypeSerializer
{
private static GsonBuilder sGsonBuilder;
static{
sGsonBuilder = new GsonBuilder();
}
@Override
public Class<?> getDeserializedType() {
return List.class;
}
@Override
public Class<?> getSerializedType() {
return String.class;
}
@Override
public String serialize(Object data) {
if(data == null){
return null;
}
final Gson gson = sGsonBuilder.create();
return gson.toJson(data);
}
@Override
public List<String> deserialize(Object data) {
if(data == null){
return null;
}
final Gson gson = sGsonBuilder.create();
List<String> strings = gson.fromJson(data.toString(), List.class);
return strings;
}
}
和MyEnum
(这是一个 enum
类型):
public class MyEnumListTypeSerializer extends TypeSerializer {
private static GsonBuilder sGsonBuilder;
static{
sGsonBuilder = new GsonBuilder();
sGsonBuilder.registerTypeAdapter(MyEnum.class, new MyEnumJsonDeserializer());
}
@Override
public Class<?> getDeserializedType() {
return new TypeToken<ArrayList<MyEnum>>(){}.getType().getClass();
}
@Override
public Class<?> getSerializedType() {
return String.class;
}
@Override
public String serialize(Object data) {
if(data == null){
return null;
}
final Gson gson = sGsonBuilder.create();
return gson.toJson(data);
}
@Override
public ArrayList<MyEnum> deserialize(Object data) {
if(data == null){
return null;
}
final Gson gson = sGsonBuilder.create();
Type listType = new TypeToken<ArrayList<MyEnum>>(){}.getType();
ArrayList<MyEnum> myList = gson.fromJson(data.toString(), listType);
return myList;
}
}
我的问题是 ActiveAndroid
序列化 MyEnum
列表类型作为字符串列表(使用 StringsListTypeSerializer
)和运行时当我使用 List<MyEnum>
时在每个循环中我得到 ClassCastException
- 无法转换 String
至 Enum
.
如何解决这个问题?
最佳答案
我用来找出不同类型的方法
public abstract class BaseGsonSerializer extends TypeSerializer {
private Gson gson;
public BaseGsonSerializer() {
this.gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
}
@DebugLog
@Override
public Class<?> getSerializedType() {
return String.class;
}
@Override
@DebugLog
public Class<?> getDeserializedType() {
return TypeToken.get(getTypeDeserialize()).getRawType();
}
@Override
public Object serialize(Object data) {
if (data != null) {
return gson.toJson(data);
}
return null;
}
@Override
public Object deserialize(Object data) {
if (data != null) {
return gson.fromJson(data.toString(), getTypeDeserialize());
}
return null;
}
protected abstract Type getTypeDeserialize();
}
以下类使用 BaseGsonSerializer
public class PriceSerializer extends BaseGsonSerializer {
protected Type getTypeDeserialize() {
return new TypeToken<Price>() {
}.getType();
}
}
public class PriceListSerializer extends BaseGsonSerializer {
protected Type getTypeDeserialize() {
return new TypeToken<List<Price>>() {
}.getType();
}
}
这正是我想要的,即转换为 json 字符串的价格列表和转换为 json 字符串的价格对象
希望这可以帮助您解决问题。
关于java - ActiveAndroid TypeSerializer - 枚举列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41543740/
如何在 ActiveAndroid 中添加两列唯一约束?我尝试添加 2.sql 并增加数据库版本,但它似乎没有正确更新(可能是因为我重新安装了应用程序?)。无论如何,有没有办法添加一些注释,我可以在
我想知道是否有可能,以及如何使用“IN”子句在ActiveAndroid中执行where子句。 例如,我想做这样的事情: 新的Select()。from(Table).where(“id in?”,l
我正在使用 ActiveAndroid作为第三方库,以便在 android 中使用 sqlite 数据库,我在使用该库创建和使用新数据库时没有任何问题,但我不知道如何将我自己的现有数据库与该库一起使用
ActiveAndroid 有一个约束,它的所有实体都需要从某个基类继承,并且需要有一个以上下文(来自 Activity )作为输入的单参数构造函数。 [不喜欢这种限制]。 使用 gson,我可以创建
我是 Android 的新手,我正在尝试将 SQLite 与 Active Android ORM 结合使用。我有一个简单的待办事项应用程序,我正在按照教程设置 Activity 的 android。
我学会了在我的 Android 应用程序中使用 ActiveAndroid,谁能告诉我如何只保存具有唯一 ID 的数据?在我的模型中,我将 id 设置为非主键列。这是我的模型类: package co
我的 Android 应用程序正在使用 DB 工具 ActiveAndroid。数据库只是一个简短的本地缓存。所有数据均从服务器重复更新。效果很好。我可以轻松地放下 table 并重新装满它们。 De
我正在使用 ActiveAndroid 并且有两个模型: @Table(name = "Topics") public class Topic extends Model { @Column(name
我想进行最简单的查询,但在网上找不到任何地方如何在 Activity 的 android 中进行查询。 我有一个 Items 表,我只想获取其中的所有项目,但我的查询只返回一个项目。 items1.
我正在尝试使用 ActiveAndroid 来处理我应用中的数据库。 这是我的模型类: package ro.adrian.trivia.datamodel; import java.io.Seria
大家好,作为我类(class)的一部分,我正在尝试测试如何在 android 中使用数据库,但我对这两者都很陌生,所以我在网上找到的大多数帮助都让我有点不知所措。 我想知道如何从表中更新和删除。目前我
我使用图书馆ActiveAndroid with RetroFit . 如果我有一个简单的模型,一切都会很好。但是如果模型包含不同的模型,我不知道所有这些是如何存储在数据库中的 我的模型: @Tabl
我尝试将 ActiveAndroid 添加到我的第一个 Android 应用程序中。到目前为止没有错误,我的项目正在保存(我用 sqlite 管理器检查过)但无论我使用什么查询,结果总是空的。我只有一
伙计们!我写了一个 Book 类,它有 Chapter 对象(一对多关系)。它实现了方法 public List chapters(),如文档中所述。这是 Book.java @Table(name
我正在使用 active android在 Android 上使用 SQLite。 例如,我有以下具有这种结构的 Pets 表: @Table(name = "Pets") public class
我在我的项目中使用 ActiveAndroid 作为 ORM 系统,我使用这行代码对数据库进行查询 List s = new Select() .from(Chats
使用 ActiveAndroid ORM 填充 RecyclerView 和跟踪数据更改的首选方法是什么? 我有 asked a question最近关于这个话题。但是它太冗长了,而且人们又很懒惰,几
我开发了一个 Android 应用程序,我使用 SQLiteOpenHelper 将数据保存在 SQLite 数据库中。 我想知道我是否可以使用 ActiveAndroid 更新我的应用程序,但会保留
您好,我正在开发 Android 应用程序,我在其中使用了 active android。我尝试使用迁移将一列添加到我的表中。我尝试使用以下代码: ALTER TABLE TAGS ADD COLUM
我正在开发一个 Android 应用程序,并考虑使用 ORM 来利用一些数据库工作,我已经看到了一些,它们似乎都适合这项工作,现在我只剩下一个主要问题,我还没有我找到了一种在运行时设置数据库位置的方法
我是一名优秀的程序员,十分优秀!