EventBus 的四种线程模式(翻译)

官方地址

ThreadMode:POSTING (default)

订阅者将在同一个线程中发布事件,这是默认情况。订阅者将在事件发布者的线程中响应事件,这是默认情况。事件传送将同步完成,一旦发布完成,所有订阅者就会被调用。这种 ThreadMode 避免了线程间的切换,因此所需的开销最小。因此,当任务简单、所需时间短、不需要占用主线程时,这种 ThreadMode 是推荐使用的。但由于事件分发可能发生在主线程,所以使用此模式的事件处理程序应该快速返回,以避免阻塞发布线程。处理函数中禁止更新UI操作。

// Called in the same thread (default)
// ThreadMode is optional here
@Subscribe(threadMode = ThreadMode.POSTING)
public void onMessage(MessageEvent event) {
    log(event.message);
}

ThreadMode: MAIN

订阅者将在主线程中响应事件。如果发布线程为主线程,那么订阅者事件将会直接响应(像 ThreadMode.POSTING 线程模式进行事件同步)。订阅者响应事件必须快速处理完自己方法内的业务以避免阻塞主线程。处理函数中禁止更新UI操作。

// Called in Android UI's main thread
@Subscribe(threadMode = ThreadMode.MAIN)
public void onMessage(MessageEvent event) {
textField.setText(event.message);
}

????疑惑:需要返回??

ThreadMode: BACKGROUD

在这种模式下,订阅者将会在非UI线程中被调用。如果事件发布所在非UI线程,那么订阅者将会在该线程中被直接调用。反之,EventBus使用单个后台线程,它将顺序地处理响应事件。在这种模式下,订阅者快速处理完自己方法内的业务以避免阻塞线程。处理函数中禁止更新UI操作。

// Called in the background thread
@Subscribe(threadMode = ThreadMode.BACKGROUND)
public void onMessage(MessageEvent event){
    saveToDisk(event.message);
}

ThradMode: ASYNC

事件处理方法会在分离的线程中被调用。订阅者所在的线程一般与主线程、事件发布线程相互独立。在这种模式下,事件发布不需要等待事件处理方法。当事件处理方法需要进行耗时操作,比如:网络请求等,这是需要使用这种模式。为了限制并发线程的数量,应避免同时触发大量长时间运行的异步处理操作。EventBus通过线程池通过重用,使用线程池从完成的异步事件处理程序通知中有效地重用线程。
EventBus 通过重用线程池中已经完成异步事件的线程来达到线程的高效复用。处理函数中禁止更新UI操作。

// Called in a separate thread
@Subscribe(threadMode = ThreadMode.ASYNC)
public void onMessage(MessageEvent event){
    backend.send(event.message);
}

你可能感兴趣的:(EventBus 的四种线程模式(翻译))