当我使用sqlbrite时,在使用groupBy()之后不能使用rxjava函数toList()。下面是我的代码:
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);
});
});这可以很好地工作,并在发出时记录所有项,但如果我将其更改为
groupedObservable.toList().subscribe(items -> {
Log.d("test", groupedObservable.getKey() + ": " + items);
});我没有正确使用toList()吗?这可能是因为sqlbrite流没有结束,所以rxjava在完成toList()之前等待发出更多的项?
发布于 2015-10-20 18:29:16
groupBy是一种特殊类型的运算符,它要求您订阅返回的GroupedObservable,否则它不会请求更多数据而会挂起。在第一个示例中,您做到了这一点,但在第二个示例中,您在没有订阅组的情况下开始累积组。
您可以做的是将组flatMapping成一对密钥和列表,这样它就不会挂起:
.groupBy(t -> ...)
.flatMap(g -> g.toList().map(lst -> Pair.of(g.getKey(), lst)))
.subscribe(...)我对SQLBrite并不熟悉,但确实,一个应用了toList的非完整源代码永远不会发出任何东西(无论是否有groupBy )。
https://stackoverflow.com/questions/33229556
复制相似问题