在Android开发中,当一个Activity(假设为A)启动另一个Activity(假设为B)时,如果B在完成某些操作后被关闭并希望通知A一些信息或告知A它已经被关闭,可以通过几种方式来实现:
1. 使用startActivityForResult()
和onActivityResult()
如果B是通过A的startActivityForResult()
方法启动的,那么当B完成时,可以调用setResult()
并结束自己(通过finish()
)。A会接收到onActivityResult()
的回调,这样就可以知道B已经关闭了,并且还可以根据B设置的结果进行相应的处理。
A Activity代码示例:
Intent intent = new Intent(this, BActivity.class); | |
startActivityForResult(intent, REQUEST_CODE); // REQUEST_CODE是一个int类型的标识符 | |
@Override | |
protected void onActivityResult(int requestCode, int resultCode, Intent data) { | |
super.onActivityResult(requestCode, resultCode, data); | |
if (requestCode == REQUEST_CODE) { | |
if (resultCode == RESULT_OK) { | |
// 处理从B返回的数据 | |
// data.get... | |
} | |
// B已关闭 | |
} | |
} |
B Activity代码示例:
// 在适当的时候设置结果并结束B | |
Intent returnIntent = new Intent(); | |
returnIntent.putExtra("resultKey", "这里是返回的数据"); | |
setResult(RESULT_OK, returnIntent); | |
finish(); |
2. 使用LocalBroadcastManager发送广播
如果A和B之间没有直接的父子关系或启动请求,但B仍需要在结束时通知A,可以使用LocalBroadcastManager
来发送一个局部广播。A可以注册一个BroadcastReceiver来监听这个广播。
B Activity中发送广播:
Intent intent = new Intent("com.example.broadcast.MY_BROADCAST"); | |
intent.putExtra("someData", "这里是返回的数据"); | |
LocalBroadcastManager.getInstance(this).sendBroadcast(intent); |
A Activity中注册和接收广播:
LocalBroadcastManager.getInstance(this).registerReceiver(mMessageReceiver, | |
new IntentFilter("com.example.broadcast.MY_BROADCAST")); | |
private BroadcastReceiver mMessageReceiver = new BroadcastReceiver() { | |
@Override | |
public void onReceive(Context context, Intent intent) { | |
// 提取数据 | |
String message = intent.getStringExtra("someData"); | |
// 处理消息 | |
} | |
}; | |
@Override | |
protected void onDestroy() { | |
LocalBroadcastManager.getInstance(this).unregisterReceiver(mMessageReceiver); | |
super.onDestroy(); | |
} |
3. 使用共享变量或单例模式
如果数据不需要实时性或者应用的其他部分也需要访问这些数据,可以考虑使用全局变量或单例模式来存储B在关闭前设置的数据。然后A可以在合适的时机(如重启Activity时)检查这些数据。
注意:这种方式可能会因为线程安全问题或数据更新时机的问题而变得复杂。
总结
推荐使用startActivityForResult()
和onActivityResult()
的方式,因为它最符合Android的设计初衷,也是处理这类问题的标准方式。其他方法如广播或共享变量/单例模式可以在更复杂的场景中使用,但需要小心处理可能的问题。