与领域的Firebase。反序列化POJO类

时间:2016-06-05 15:15:08

标签: android firebase firebase-realtime-database

我的firebase数据库中有数据,一切正常,直到我尝试反序列化数据。

错误:参数1的类型为io.realm.RealmList,java.util.ArrayList

这是我的代码:

 DatabaseReference root = FirebaseDatabase.getInstance().
                getReferenceFromUrl("https://swing-8792d.firebaseio.com/playlist");
        Query playlistQuery = root.orderByKey().equalTo(key);
        playlistQuery.addListenerForSingleValueEvent(new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                for (DataSnapshot child : dataSnapshot.getChildren()) {

                    Log.d("Child", child + "");

                    Playlist receivedPlaylist = child.getValue(Playlist.class);
                    Playlist playlist = new Playlist();

                    playlist.setCreatedBy(receivedPlaylist.getCreatedBy());
                    playlist.setName(receivedPlaylist.getName());
                    playlist.setMyMap(receivedPlaylist.getMyMap());
                    playlist.setQrKey(receivedPlaylist.getQrKey());
                    playlist.setCount(receivedPlaylist.getCount());
                    playlist.setId(receivedPlaylist.getId());
                    playlist.setTracks(receivedPlaylist.getTracks());
                    mPlaylist.add(playlist);
 }

这是我的POJO课程:

@RealmClass
public class Playlist extends RealmObject {

String name;
Long id;
RealmList<Track> tracks;
Integer count;
String createdBy;
RealmList<UserMap> myMap;
String qrKey;

public RealmList<UserMap> getMyMap() {
    return myMap;
}

public void setMyMap(RealmList<UserMap> myMap) {
    this.myMap = myMap;
}

public Playlist(){}



public String getQrKey() {
    return qrKey;
}

public void setQrKey(String qrKey) {
    this.qrKey = qrKey;
}

public String getCreatedBy() {
    return createdBy;
}

public void setCreatedBy(String createdBy) {
    this.createdBy = createdBy;
}


public RealmList<Track> getTracks() {
    return tracks;
}

public void setTracks(RealmList<Track> tracks) {
    this.tracks = tracks;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public Long getId() {
    return id;
}

public void setId(Long id) {
    this.id = id;
}

public Integer getCount() {
    return count;
}

public void setCount(Integer count) {
    this.count = count;
}

}

如果我尝试使用普通POJO类(即删除领域)进行反序列化,它可以正常工作。

2 个答案:

答案 0 :(得分:4)

Firebase不会使用没有default构造函数或私有变量的类,即没有公共getter / setter。

在您的情况下,一个更简单的解决方案是创建一个只是不扩展RealmObject的中间件类。接下来使用pojo的值初始化您的RealmObject子类。

伪代码

class SimplePojoPlaylist  {
     public String variable;
}

class Playlist extends RealmObject {
     public String variable;
}

然后首先投入SimplePojoPlaylist

    for (DataSnapshot child : dataSnapshot.getChildren()) {
         SimplePojoPlaylist receivedPlaylist = child.getValue(SimplePojoPlaylist.class);
         Playlist playList = new Playlist();
         playList.variable = receivedPlaylist.variable;
    }

答案 1 :(得分:1)

RealmList不是反序列化支持的类型。您的数据库检查其结构并推断该轨道应该是ArrayList。然后,当它尝试转换它时,它会发现类型不匹配。

Check this link from the docs:

此外,最好使对象不可变,以避免不必要的访问和/或修改。

从头开始创建一个空对象,然后调用setter方法来定义它的状态不是一个非常好的模式,因为它可以创建一个对象在其状态被打破之前被访问的情况#34;

如果您需要创建一个灵活的对象,有一些必填字段和一些可选字段,请考虑使用Builder模式,尽管如此,您还必须重新设计模型。

wikipedia - Builder

如果您不需要/想要使用建筑商,我的建议是:

1)将空构造函数设为私有,并创建另一个需要所有字段的公共构造函数。

2)将您的曲目字段更改为类型&#34;列表&#34;。然后,如果您需要该对象返回一个RealmList,则创建另一个getter方法,例如tracksAsRealmList(),它将RealmList从成员列表中移出并返回它。

3)确保&#34;跟踪&#34; model有一个空的私有构造函数,一个包含所有参数的公共构造函数,并且firebase反序列化支持它的所有字段。

4)除非绝对必要,否则请将对象字段设为私有,并通过setter方法设置其值。

我希望这会对你有所帮助。