入栈的Activity由于系统资源不足被被回收了怎么办

当一个活动进入到了停止状态,是有可能被系统回收的。那么想象以下场景

应用中有一个活动 A,用户在活动 A 的基础上启动了活动 B,活动 A 就进入了停止状态,这个时候由于系统内存不足,将活动 A 回收掉了,然后用户按下 Back 键返回活动 A, 会出现什么情况呢?其实还是会正常显示活动 A的, 只不过这时并不会执行 onRestart()方法,而是会执行活动 A 的 onCreate()方法,因为活动 A 在这种情况下会被重新创建一次。这样看上去好像一切正常,可是别忽略了一个重要问题,活动 A 中是可能存在临时数据和状态的。

打个比方,MainActivity 中有一个文本输入框,现在你输入了一段文字,然后启动 NormalActivity,这时 MainActivity 由于系统内存不足被回收掉,过了一会你又点击了Back 键回到 MainActivity,你会发现刚刚输入的文字全部都没了,因为 MainActivity 被重新创建了。

如果我们的应用出现了这种情况,是会严重影响用户体验的,所以必须要想想办法解决这个问题。查阅文档可以看出,Activity 中还提供了一个 onSaveInstanceState()回调方法,这个方法会保证一定在活动被回收之前调用,因此我们可以通过这个方法来解决活动被回收时临时数据得不到保存的问题。

onSaveInstanceState()方法会携带一个 Bundle 类型的参数,Bundle 提供了一系列的方法用于保存数据,比如可以使用 putString()方法保存字符串,使用 putInt()方法保存整型数据,以此类推。每个保存方法需要传入两个参数,第一个参数是键,用于后面从 Bundle 中取值,第二个参数是真正要保存的内容。

在 MainActivity 中添加如下代码就可以将临时数据进行保存:
@Override

protected void onSaveInstanceState(Bundle outState) {

super.onSaveInstanceState(outState);

  String tempData = "Something you just typed";

  outState.putString("data_key", tempData);

}

数据是已经保存下来了,那么我们应该在哪里进行恢复呢?细心的你也许早就发现,我们一直使用的 onCreate()方法其实也有一个 Bundle 类型的参数。这个参数在一般情况下都是null,但是当活动被系统回收之前有通过 onSaveInstanceState()方法来保存数据的话,这个参数就会带有之前所保存的全部数据,我们只需要再通过相应的取值方法将数据取出即可。

修改 MainActivity 的 onCreate()方法,如下所示:
@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

Log.d(TAG, "onCreate");

requestWindowFeature(Window.FEATURE_NO_TITLE);

setContentView(R.layout.activity_main);

if (savedInstanceState != null) {

String tempData = savedInstanceState.getString("data_key");

Log.d(TAG, tempData);

}

……

}

取出值之后再做相应的恢复操作就可以了,比如说将文本内容重新赋值到文本输入框上,这里我们只是简单地打印一下。
不知道你有没有察觉,使用 Bundle 来保存和取出数据是不是有些似曾相识呢?没错!我们在使用 Intent 传递数据时也是用的类似的方法。这里跟你提醒一点,Intent 还可以结合Bundle 一起用于传递数据的,首先可以把需要传递的数据都保存在 Bundle 对象中,然后再将 Bundle 对象存放在 Intent 里。到了目标活动之后先从 Intent 中取出 Bundle,再从 Bundle
中一一取出数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当后台的Activity由于系统回收而被销毁时,我们可以通过保存当前状态的方法来在Activity被重新创建时恢复之前的状态。以下是一些保存和恢复Activity状态的常用方法: 1. onSaveInstanceState() 和 onRestoreInstanceState() 方法: - 在Activity被销毁之前,系统会调用 onSaveInstanceState() 方法。我们可以在该方法中保存需要恢复的数据到 Bundle 对象中。 - 在Activity重新创建后,系统会调用 onRestoreInstanceState() 方法,并将之前保存的 Bundle 对象作为参数传递给该方法。我们可以从 Bundle 中恢复之前保存的数据,并进行相应的处理。 2. 使用 SharedPreferences: - 在 Activity 的 onDestroy() 方法中,将需要保存的状态数据存储到 SharedPreferences 中。 - 在 Activity 的 onCreate() 方法中,从 SharedPreferences 中读取数据,并进行恢复。 3. 使用数据库或文件存储: - 在 Activity 的 onDestroy() 方法中,将需要保存的状态数据存储到数据库或文件中。 - 在 Activity 的 onCreate() 方法中,从数据库或文件中读取数据,并进行恢复。 需要注意的是,以上方法并不能保证在所有情况下都能完全恢复 Activity 的状态。在某些极端情况下,如系统内存严重不足或用户主动关闭应用等情况下,Activity 可能无法被恢复到之前的状态。因此,除了保存和恢复 Activity 状态外,还应该设计合理的应用程序结构和逻辑,以确保用户体验的连贯性。 另外,为了最大程度地减少 Activity 被系统回收的可能性,可以考虑使用一些优化措施,如避免在后台长时间占用内存的操作、使用合理的资源释放策略等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值