今天介绍一种方法,调用Activity的方法,适用于在加载数据完成后,或者加载失败,等多种情况。
先简单来个例子
代码:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
protected void onResume() {
super.onResume();
BusProvider.getInstance().register(this);
BusProvider.getInstance().post(new Success());
}
@Override
protected void onPause() {
super.onPause();
BusProvider.getInstance().unregister(this);;
}
@Subscribe
public void onSuccess(Success success){
Log.v("sss","success");
}
代码主要就是3个生命周期函数,还有个自定义的onSuccess方法,在onResume和onPause中注册了该对象,就是说该对象可以接收订阅消息了。所谓订阅��息是指,@Subscribe注释的方法,当BusProvider.getInstance().post(new Success());发送了Success对象的时候,就会被该方法接收。在onPause后就取消注册,就不再接收方法。
运行结果:
这有什么用呢?
我们经常异步去加载数据,数据加载好了之后通知activity更新界面,就可以使用这种方法,非常有效的通知activity。
上面的例子很简单,但是还有些地方需要注意下,就是
BusProvider.getInstance().post(new Success());
需要写在注册对象的后面,只有注册后,才能接收订阅消息。
一般注册和取消注册都是放在onResume 和onPause2个生命周期函数中的,难道说,我们取数据一定要在onResume后面嘛?当然不是了。
我们可以这样:
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
new Handler().post(new Runnable() {
@Override
public void run() {
BusProvider.getInstance().post(new Success());
}
});
}
运行效果:
还是可以的。
这是因为我们把BusProvider.getInstance().post(new Success());压入主线程的线程队列中。
这时,我们又遇到一个问题,就是一般我们都是异步去获取数据的,而不是在主线程,这时候怎么办呢?
new Thread(new Runnable() {
@Override
public void run() {
BusProvider.getInstance().post(new Success());
}
}).start();
对,直接开个线程,然后运行:
报错。
这是因为,在new Bus时,需要带个参数,不带参数,默认指,只能在主线程发送消息。
所以我们要带上参数new Bus(ThreadEnforcer.ANY);
让Bus在任意线程中都可以传送数据。
这时,没有报错,但是,却没有任何输出。
在run中 加上
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
发现有输出。
还是因为在注册前先发送了消息。