- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在结合使用 Realm (0.88.2) 和 Retrofit 2 来检索一些对象。当我尝试使用“copyToRealmOrUpdate”将对象复制/更新到我的 Realm 时,抛出 IllegalArgumentException,并显示消息“无法从另一个 Realm 实例复制对象”。
我的 Retrofit 调用的 onResponse:
public void onResponse(Call<List<Werkbon>> call, Response<List<Werkbon>> response) {
if (response.isSuccess()){
Realm realm = Realm.getDefaultInstance();
realm.beginTransaction();
realm.copyToRealmOrUpdate(response.body());
realm.commitTransaction();
realm.close();
}
}
我也尝试过在 response.body() 上使用 for 循环,尝试一个一个地添加对象,导致相同的错误/消息。
抛出的错误:
03-21 15:32:25.754 27465-27465 E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.vl.test, PID: 27465
java.lang.IllegalArgumentException: Cannot copy an object from another Realm instance.
at io.realm.RealmList.copyToRealmIfNeeded(RealmList.java:246)
at io.realm.RealmList.add(RealmList.java:181)
at io.realm.WerkbonRealmProxy.copy(WerkbonRealmProxy.java:732)
at io.realm.WerkbonRealmProxy.copyOrUpdate(WerkbonRealmProxy.java:696)
at io.realm.DefaultRealmModuleMediator.copyOrUpdate(DefaultRealmModuleMediator.java:330)
at io.realm.Realm.copyOrUpdate(Realm.java:1395)
at io.realm.Realm.copyToRealmOrUpdate(Realm.java:765)
at io.realm.Realm.copyToRealmOrUpdate(Realm.java:814)
at com.example.app.datamodel.werkbon.Werkbon$1.onResponse(Werkbon.java:81)
at retrofit2.ExecutorCallAdapterFactory$ExecutorCallbackCall$1$1.run(ExecutorCallAdapterFactory.java:66)
at android.os.Handler.handleCallback(Handler.java:746)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5443)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:728)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
问题:为什么会抛出这个错误,我怎样才能将这些对象放入我的 Realm ?
最佳答案
在 beeender 的帮助下回答我自己的问题在评论中。
我的 Werkbon
对象包含 RealmLong
对象的 RealmList
。 RealmLong 只是一个长值的容器。
在 Retrofit 中,我添加了一个 TypeAdapter 来将 longs
转换为这些 RealmLongs
。在这个适配器中,我已经将 RealmLong 添加到 Realm 中,如下所示:
mGson = new GsonBuilder()
.registerTypeAdapter(RealmLong.class, new RealmLongDeserializer())
...
.create()
和 TypeAdapter 本身,其中 RealmLongs 被添加到一个 Realm :
// Don't copy this, wrong version! Scroll down for correct TypeAdapter
private class RealmLongDeserializer implements JsonDeserializer<RealmLong> {
@Override
public RealmLong deserialize(JsonElement jsonElement, Type typeOF,
JsonDeserializationContext context) throws JsonParseException {
Realm realm = Realm.getDefaultInstance();
realm.beginTransaction();
RealmLong rl = realm.createObject(RealmLong.class);
rl.setVal(jsonElement.getAsLong());
realm.commitTransaction();
realm.close();
return rl;
}
}
但是,我不必将此添加到 Realm,因为 Werkbon
的 copyToRealmOrUpdate
函数已在后期执行此操作。因此 TypeAdapter 可以如下所示:
private class RealmLongDeserializer implements JsonDeserializer<RealmLong> {
@Override
public RealmLong deserialize(JsonElement jsonElement, Type typeOF,
JsonDeserializationContext context) throws JsonParseException {
RealmLong rl = new RealmLong(jsonElement.getAsLong());
return rl;
}
}
关于android - 无法将 Retrofit 生成的 RealmObject 复制到 Realm : IllegalArgumentException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36134124/
我遇到了 Realm 问题,每次我尝试在存储 RealmObject 后将其设置为另一个 RealmObject 时,都会导致它崩溃并出现 NullPointerException。 例如。
我想从它的 Realm 中“分离”一个 RealmObject,这意味着我希望能够从一个方法中返回一个 RealmObject并能够在我关闭 Realm 实例后使用它。 像这样: public Per
直接上代码。我们有两个类: class Rocket extends RealmObject { @PrimaryKey private long id; private String name
写入 Realm : Realm realm = Realm.getInstance(mContext); realm.beginTransaction(); InfoCocktail content
考虑以下 RealmObject 子类 public class TimeSlot extends RealmObject { @PrimaryKey private int value = 0;
假设我的 Realm 数据库中有三个对象/元素:- 一个 B C 当我使用方法deleteFromRealm() 删除第一个元素(即 A)时,剩余两个对象的位置会像这样改变:- C B 而不是:- B
我有一个 RealmObject User 存储在一个单例中并在整个应用程序中访问——它是在 UI 线程上检索的。该对象表示已登录的用户,与 Item 类具有一对多关系。在事务中更改它时,例如: Re
我是 Realm 的新手,我想坚持以下模型: public class ChangeEntry { private int id; private long time; pri
我试图从官方文档的“通知”部分了解 Realm 中的通知类型,当我在多个托管对象中使用 RealmObject addChangeListener 时,只有一个对象发生变化时,所有这些通知类型都会被调
我的应用从 REST API 获取数据。 根据端点,我得到完整或部分 Account 的列表。 当 API 响应时,我调用 realm.copyToRealmOrUpdate(accounts)。 我
我在我的项目中做 Realm 数据库。当您使用 Realm 时,您需要将简单对象扩展为 RealmObject。我有一个问题:如何在不扩展 RealmObject 的情况下创建对象,但我也使用 Rea
我的 Android 应用程序中有一个配置类,我将其存储在 Realm 数据库中。我只是对其进行了编辑以遵循单例设计模式,因此只有一次配置实例。 问题是,该类现在有一个私有(private)构造函数,
为什么这段代码会触发 java.lang.IllegalArgumentException: RealmObject 无效,因此无法复制 错误? realm.beginTransaction(); r
documentation对于 realmObject.isValid() 说: isValid() Checks if the realmObject is still valid to use i
我在我的 android 应用程序中使用 Realm 作为数据模块,尽管我遇到了一些关于如何将自定义方法分配给 Realm 对象的问题。在 iOS 核心数据模块中,您有 NSObjects,它们保存到
在我的应用程序中,我有以下 RealmObjects: 产品 - 这作为主数据,不应修改。 购物车 - 购物车允许人们挑选要购买的东西。内容将是选择类型。 选择 - 表示用户选择的产品以及颜色、尺寸等
我在 Android 上使用 Realm,我有一个需要序列化为 JSON 的 RealmObject,我正在使用 GSON。模型看起来像: @RealmClass public class User
我是 Android 版 Realm 的新手,所以我不确定我是否以正确的方式处理这个问题。我有一个看起来像这样的类: public class Entry extends RealmObject im
我们有一个简单的类Person,它继承自 Realm Object。现在我们希望该子类符合 Equatable 协议(protocol)。非常简单的代码如下所示。 class Person: Obje
假设异步API调用返回Member Data,它是一个RealmObject,并且Member被保存到realm中。 public class Member extends RealmObject {
我是一名优秀的程序员,十分优秀!