- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我很欣赏 RxJava 可以处理的所有复杂性,从处理用户事件到大型复杂的响应式(Reactive)算法结构。然而,我仍然在为源的开始而苦苦挣扎 Observable
以及所有事件的来源,以及如何管理多个事件来源。
我知道这个问题的答案可能是“视情况而定”,但将源事件合并到单个 Subject
是否是个坏主意?还是某种形式的 Hot Observable?
例如,假设我有一个数据驱动的桌面应用程序。我有一个可枚举的标识根级事件类型。
public enum AppEvent {
TRANSACTIONS_REFRESH,
CATEGORIES_REFRESH
}
然后我有一个 AppEventEngine
包含 PublishSubject
的单例并提供一种发布事件和访问 Observable<AppEvent>
的方法.
public final class AppEventEngine {
private static final AppEventEngine instance = new AppEventEngine();
private final PublishSubject<AppEvent> eventBus = PublishSubject.create();
public void post(AppEvent appEvent) {
eventBus.onNext(appEvent);
}
public Observable<AppEvent> getEvents(AppEvent appEvent) {
return eventBus.startWith(appEvent).filter(e -> e.equals(appEvent));
}
public static AppEventEngine get() {
return instance;
}
private AppEventEngine() {}
}
然后我可以发出 AppEvent.CATEGORIES_REFRESH
到 CategoryManager
并使用 RxJava-JDBC构建并发出一个新的 List<Category>
来自查询。
public final class CategoryManager {
private final Database db = //instantiate database;
private final Observable<List<Category>> categories;
private CategoryManager() {
categories = AppEventEngine.get().getEvents(AppEvent.CATEGORIES_REFRESH)
.flatMap(e -> db.select("SELECT * FROM CATEGORY").get(rs -> new Category(rs.getInt("ID"), rs.getString("DESC"))).toList()).cache(1);
}
public Observable<List<Category>> getCategories() {
return categories;
}
}
然后外部客户端类不仅可以转换和订阅 Observable<List<Category>>
还要推送AppEvent.CATEGORIES_REFRESH
随时发生的事件。
public final class SomeClientUX {
//gui code
public void categoryRefreshButtonPressed() {
AppEventEngine.get().post(AppEvent.CATEGORIES_REFRESH);
}
}
我的问题是...正在关注此 EventBus
pattern ( much like that in Google Guava ) 是一种编写 RxJava 桌面应用程序的方式吗?或者我应该避免使用 PublishSubject
并以不同的方式(以分散的方式)导出事件?
最佳答案
我认为这是一个有效的模式,并且是 PublishSubject
的常见用例。如果您希望事件从不同的线程推送到它(除非推送的事件之间存在正式的先行发生关系,但这是一种优化你可能不需要)。所以声明应该是:
private final Subject<AppEvent> eventBus =
PublishSubject.create().toSerialized();
关于java - RxJava- 一个单一的热源 Observable?好主意还是坏主意?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32235209/
我正在进行 2 个 RX 调用,这些调用相互嵌套且相互依赖。服务器存在问题(由于各种原因目前无法解决),该问题在第二个嵌套调用中返回错误。 在这个问题得到解决之前,我需要确保如果第二次调用返回错误,则
这个问题在这里已经有了答案: How to resolve Duplicate files copied in APK META-INF/rxjava.properties (8 个答案) 关闭 5
我正在尝试将此 RxJava1 代码转换为 RxJava2 public static Observable listFolder(Path dir, String glob) { retur
这个问题在这里已经有了答案: RxJava 1 and RxJava 2 in the same project [duplicate] (1 个回答) How to resolve Duplica
有显示项目的RecyclerViewAdapter(该项目已经映射到数据库中)。 RecyclerViewAdapter 包含对 Presenter 的引用以加载项目。它还包含带有项目 ID 的 Ar
我想弄清楚如何在 Android 中使用 RxJava 将 Realm 对象保存在 Realm 中。到目前为止,结合所有这些的所有示例都是如何从 Realm 读取数据的。我想在 android 中使用
我在日志中收到此错误: Caused by java.lang.ClassCastException: java.net.UnknownHostException cannot be cast to
我有一个 API 服务类,其方法返回 Retrofit 提供的调用。 最近,Rx2Java 引入了 Single,所以我想将 Call 更改为 Single,但我不想更改逻辑。 例如 : 类接口(in
如何使用运算符让我始终获得以前和当前的值?如果可能的话,我想避免在管道外创建状态。 - time -> 1 2 3 4 | | | | Op
我正在努力实现以下目标。我加载了一个对象列表,我想获取稍后放入列表中的值。 首先,我使用 flatmap 将所有值收集到一个数组中(按山顺序),然后当一切完成后,我填充一个适配器。 我无法做的是每
是否可以选择使用 timeout 的变体不发射 Throwable ? 我要 complete事件发出。 最佳答案 您不需要使用 onErrorResumeNext 映射错误。您可以使用以下方法提供备
我们可以在 C# Rx 中异步执行一些代码,如下所示,使用 Observable.Start()。我想知道 RxJava 中的等价物是什么。 void Main() { AddTwoNum
问题:我有一个用户可以输入查询字符串的功能,我制作了 2 个可观察对象,一个用于查询我的本地数据库,另一个用于从 API 获取结果。这两个操作必须并行运行。我需要尽快显示来自数据库的结果,当 API
我正在尝试在 MVVM 中实现 ViewModel,将可观察对象作为“输入流”提供,将观察者作为“输出流”提供以供 View 绑定(bind)。 如果 getUser() 调用成功,下面的代码似乎可以
出于某种原因,我有时想使用 RxOperators 而不是普通的 java 方式来转换数据结构,因为它越来越干净。例如: Observable.from(listOfStrings) .filter(
我是 RxJava 新手,我需要以异步方式使用 Observable 功能。 我还需要使用超时:在我的示例中,我希望每个进程在 1 秒或更短的时间内结束。 这是我现在所做的: public stati
我正在尝试在网络请求期间在UI中显示进度条至少3秒钟。 此答案中描述的相同方法似乎不适用于Single。 RxJava Observable minimum execution time Single
我有一个可观察的(很热),它通过系统进程执行操作,并且我希望也运行一个间隔,直到该进程可观察达到 onComplete。 我看到区间运算符:http://reactivex.io/documentat
好吧,我是 RxJava2 的新手(嗯,我也不了解 RxJava),并且正在尝试使用 RxJava2 和 MVP 结构开发 Android 应用程序。 在该应用程序中,我正在对使用监听器的库进行异步调
如何将单个流拆分为单独的单个流,这样就可以执行以下操作而无需两次计算getUserId()? // getUserId() returns Single getUserId().flatMap { g
我是一名优秀的程序员,十分优秀!