异常情况下的生命周期分析

1. 资源相关的系统配置发生改变导致Activity被杀死并重新创建

比如,屏幕旋转,默认情况下Activity会被销毁并且重新创建,不过我们也可以阻止系统重新创建我们的Activity

  • 当系统配置发生改变后,Activity会被销毁,起onPause,onStop,onDestroy方法均会被调用
  • 同时,由于Activity是在异常情况下终止,系统会调用onSaveInstanceState来保存当前Activity的状态。该方法的调用时机是在onStop之前,它和onPause没有既定的时序关系,它既可能在onPause之前调用,也可能在onPause之后调用
  • 需要注意的是,该方法只会出现在Activity被异常终止的情况下,正常情况下系统不会回调这个方法
  • 当Activity被重新创建后,系统会调用onRestoreInstanceState,并且把Activity销毁时onSaveInstanceState方法所保存的Bundle对象作为参数同时传递给onRestoreInstanceState和onCreate方法
  • 因此,可以通过onRestoreInstanceState和onCreate方法来判断Activity是否被重建了,如果被重建了,那么我们就可以取出之前保存的数据并恢复
  • 从时序上来说,onRestoreInstanceState的调用时机在onStart之后

在onSaveInstanceState和onRestoreInstanceState方法中,系统会自动为我们做一定的恢复工作

当Activity在异常情况下需要重新创建时,系统会默认为我们保存当前Activity的视图结构,并且在Activity重启后为我们恢复这些数据

比如:TextView中用户输入的数据、ListView滚动的位置

具体针对某一特定的View,系统能为我们恢复哪些数据,可以查看View的源码

和Activity一样,每个View都有onSaveInstanceState和onRestoreInstanceState这两个方法,看一下它们的具体实现,就知道系统能够自动为每个View恢复哪些数据

保存和恢复View层次结构时,系统的工作流程

  1. Activity被意外终止->调用onSaveInstanceState去保存数据
  2. Activity委托Window去保存数据,Window委托它上面的顶级容器去保存数据
  3. 顶级容器是一个ViewGroup,一般来说它很有可能是DecorView
  4. 顶层容器再去一一通知它的子元素来保存数据,这样整个数据保存过程就完成了

这是一种典型的委托思想,这种思想在Android中有很多应用,比如View的绘制过程,事件的分发等都是采用类似的思想

在onCreate和onSaveInstanceState中恢复数据

  • 两者的区别:
  • ​onRestoreInstanceState一旦被调用,其参数Bundle savedInstanceState一定是有值的,我们不用额外地判断是否为空
  • onCreate如果是在正常启动的情况下,起参数是为null的,所以在onCreate中需要进行额外判断
  • 这两个方法我们选择任意一个都可以进行数据恢复,但是官方文档建议是采用onRestoreInstanceState去恢复数据

针对onSaveInstanceState方法需要说明,就是系统只会在Activity即将被销毁并且有机会重新显示的情况下才回去调用它

所以,当Activity正常销毁的时候,系统不会调用onSaveInstanceState,因为被销毁的Activity不可能再次被显示

比如,旋转屏幕所造成的Activity异常销毁,这个过程和正常停止Activity时不一样的,因为旋转屏幕后,Activity被销毁的同时会立刻创建新的Activity实例,这时候Activity有机会再次立刻展示,所以系统要进行数据存储

这里可以简单的理解,系统旨在Activity异常终止的时候才会调用onSaveInstanceState和onRestoreInstanceState来存储和恢复数据,其他情况下不会触发这个过程

2. 资源内存不足导致低优先级的Activity被杀死

Activity的优先级排序(从高到低)

  1. 前台Activity:正在和用户进行交互的Activity,优先级最高
  2. 可见但非前台的Activity:比如Activity中弹出了一个对话框,导致Activity可见,但是位于后台无法和用户直接交互
  3. 后台Activity:已经被暂停的Activity,比如执行了onStop,优先级最低

当系统内存不足的时候,系统就会按照上述优先级去杀死目标Activity所在的进程,并且在后续通过onSaveInstanceState和onRestoreInstanceState来存储和恢复数据

如果一个进程没有四大组件在执行那么这个进程很快被系统杀死,比较好的方法是将后台工作放入Service中从而保证进程有一定的优先级,这样就不会轻易的被系统杀死

3. 当系统配置发生改变后,避免Activity被重新创建

  • 系统配置中有很多内容,如果当某项内容发生改变后,我们不想重新创建Activity,可以给Activity指定configChange属性
  • 在配置过configChange参数后,屏幕旋转并没有调用onSaveInstanceState和onRestoreInstanceState来存储和恢复数据,取而代之的是系统调用了Activity的onConfigurationChanged方法,这个时候我们就可以做一些自己的特殊处理了

第一章02-异常情况下Activity的生命周期的更多相关文章

  1. 第一章01-正常情况下Activity的生命周期

    一.Android下能见到的界面 Window Dialog Toast Activity 二.Activity的生命周期分析 典型情况下的生命周期 ​是指在有用户参与的情况下,Activity所经过 ...

  2. Android开发艺术探索笔记——第一章:Activity的生命周期和启动模式

    Android开发艺术探索笔记--第一章:Activity的生命周期和启动模式 怀着无比崇敬的心情翻开了这本书,路漫漫其修远兮,程序人生,为自己加油! 一.序 作为这本书的第一章,主席还是把Activ ...

  3. Android之Activity的生命周期

    PS:写一发关于Activity的生命周期,也算是面试的重点内容. 学习内容: 1.Activity的生命周期 2.面对多种情况的时候Activity的生命周期 3.onSaveInstanceSta ...

  4. 浅谈Android中Activity的生命周期

    引言 我想对于Android开发人员来说,Activity是再熟悉不过了,今天我们就来探讨下Activity的生命周期.熟悉的掌握Activity对于开发健壮的Android应用程序来说至关重要.下面 ...

  5. 异常情况下的Activity生命周期分析

    情况1:资源相关的系统配置发生改变 资源相关的系统配置发生改变,举个栗子.当前Activity处于竖屏状态的时候突然转成横屏,系统配置发生了改变,Activity就会销毁并且重建,其onPause, ...

  6. 第一章:Activity的生命周期和启动模式

    Activity是Android中四大组件之首,所以需要重视,尤其是启动方式,在AndroidManifest.xml中的注册信息 (一)Activity的生命周期 1.1.1 正常情况下的生命周期 ...

  7. 《Android开发艺术探索》读书笔记 (1) 第1章 Activity的生命周期和启动模式

    第1章 Activity的生命周期和启动模式 1.1 Activity生命周期全面分析 1.1.1 典型情况下生命周期分析(1)一般情况下,当当前Activity从不可见重新变为可见状态时,onRes ...

  8. Android DevArt2:Android 5.0下 Dialog&AlertDialog 并不会影响Activity的生命周期

    先给出结论:Dialog和AlertDialog并不会影响到Activity的生命周期,但会影响到Activity的优先级. 核心代码: onCreated中: Resources resources ...

  9. 第三章:Activity的生命周期

    一:Activity的生命周期方法 Android提供了很多Activity的生命周期方法,比如我们常用的onCreate.onPause.onResume等.这里主要介绍粗粒度的周期方法,诸如onP ...

随机推荐

  1. CCF ISBN

    题目原文 问题描述(题目链接登陆账号有问题,要从这个链接登陆,然后点击“模拟考试”,进去找本题目)   试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256 ...

  2. Docker学习笔记(三):Dockerfile及多步骤构建镜像

    Dockerfile指令 官方文档地址:https://docs.docker.com/engine/reference/builder/ Dockerfile是一个文本格式的配置文件,其内容包含众多 ...

  3. UVALive8518 Sum of xor sum

    题目链接:https://vjudge.net/problem/UVALive-8518 题目大意: 给定一个长度为 $N$ 的数字序列 $A$,进行 $Q$ 次询问,每次询问 $[L,R]$,需要回 ...

  4. 如何在手机上预览本地h5页面

    很简洁的一个方法: 1.安装nodeJS环境 2.在当前所在项目文件夹下输入命令: npm install anywhere -g3.输入命令: anywhere,即可在浏览器以本机ip地址为域名,自 ...

  5. Collection接口和list,set子类

    Collection接口常用的子接口有:List接口.Set接口List接口常用的子类有:ArrayList类.LinkedList类Set接口常用的子类有:HashSet类.LinkedHashSe ...

  6. MSC添加shard节点

    1.MSC添加shard节点 mkdir -p /mongodb/38027/conf  /mongodb/38027/log  /mongodb/38027/datamkdir -p /mongod ...

  7. Spring MVC介绍和第一个例子

    1.Spring mvc概述 spring mvc是spring提供给web应用框架设计,实际上MVC框架是一个设计理念.它不仅存在java世界中而且广泛在于各类语言和开发中,包括web的前端应用.对 ...

  8. golang垃圾回收机制

    golang的GC,1.8通过混合写⼊屏障, 使得STW降到了sub ms.go语言中程序代码执行和垃圾回收是并发执行的. 当前Go GC特征 :三色标记,并发标记和清扫,非分代,非紧缩,混合写屏障. ...

  9. [256个管理学理论]006.刺猬效应(Hedgehog Effect)

    刺猬效应(Hedgehog Effect) 来自于大洋彼岸的让你看不懂的解释: 刺猬效应(刺猬法则)就是人际交往中的“心理距离效应”.人与人之间都应该保持这条底线,过犹不及. 刺猬效应强调的就是人际交 ...

  10. 2020 网鼎杯wp

    2020 网鼎杯WP 又是划水的一天,就只做出来4题,欸,还是太菜,这里就记录一下做出的几题的解题记录 AreUSerialz 知识点:反序列化 打开链接直接给出源码 <?php include ...