3
当我使用sqlbrite时,在使用groupBy()后我不能使用rxjava函数toList()。这里是我的代码:使用groupBy和toList rxjava函数和sqlbrite
QueryObservable query = jetAnywhereDB.createQuery(Item.TABLE, "SELECT * FROM testTable");
query.flatMap(q -> {
return q.asRows(Item.MAPPER);
}).
groupBy(item -> {
return Character.toUpperCase(item.name.charAt(0));
}).
subscribe(groupedObservable -> {
groupedObservable.subscribe(item -> {
Log.d("test", groupedObservable.getKey() + ": " + item.name);
});
});
这工作正常,并记录所有的项目,因为他们得到发出的,但如果我不是我()正确使用toList将其更改为
groupedObservable.toList().subscribe(items -> {
Log.d("test", groupedObservable.getKey() + ": " + items);
});
?这可能是因为sqlbrite流没有结束,所以在完成toList()之前,rxjava正在等待更多的项目发出?
所以它看起来像onComplete从来没有要求sqlbrite(https://github.com/square/sqlbrite/issues/36)。在这种情况下有没有办法使用groupBy? –
如果你使用'groupBy',那么是,但'toList'不起作用。你必须通过'timeout()'来停止源代码,或者使用time-bound'buffer()'代替'toList'。 – akarnokd
应该接受答案。有时候冷热的东西是痛苦的 –