一、onSaveInstanceState

Called to retrieve per-instance state from an activity before being killed so that the state can be restored in onCreate(Bundle) or onRestoreInstanceState(Bundle) (the Bundle populated by this method will be passed to both).

This method is called before an activity may be killed so that when it comes back some time in the future it can restore its state.

The default implementation takes care of most of the UI per-instance state for you by calling onSaveInstanceState() on each view in the hierarchy that has an id, and by saving the id of the currently focused view (all of which is restored by the default implementation of onRestoreInstanceState(Bundle)).

If called, this method will occur before onStop(). There are no guarantees about whether it will occur before or after onPause().

tip:

In situations where the system needs more memory it may kill paused processes to reclaim resources. Because of this, you should be sure that all of your state is saved by the time you return from this function. In general onSaveInstanceState(Bundle) is used to save per-instance state in the activity and onStop() is used to store global persistent data (in content providers, files, etc.)

二、onRestoreInstanceState

This method is called after onStart() when the activity is being re-initialized from a previously saved state, given here in savedInstanceState. Most implementations will simply use onCreate(Bundle) to restore their state, but it is sometimes convenient to do it here after all of the initialization has been done or to allow subclasses to decide whether to use your default implementation. The default implementation of this method performs a restore of any view state that had previously been frozen by onSaveInstanceState(Bundle).

onRestoreInstanceState() is called only when recreating activity after it was killed by the OS. Such situation happen when:

  • orientation of the device changes (your activity is destroyed and recreated)
  • there is another activity in front of yours and at some point the OS kills your activity in order to free memory (for example). Next time when you start your activity onRestoreInstanceState() will be called.

In contrast: if you are in your activity and you hit Back button on the device, your activity is finish()ed (i.e. think of it as exiting desktop application) and next time you start your app it is started "fresh", i.e. without saved state because you intentionally exited it when you hit Back.

Other source of confusion is that when an app loses focus to another app onSaveInstanceState() is called but when you navigate back to your app onRestoreInstanceState() may not be called. This is the case described in the original question, i.e. if your activity was NOT killed during the period when other activity was in front onRestoreInstanceState() will NOT be called because your activity is pretty much "alive".

三、案例实验

  • 第一次进入应用

    02-09 22:47:39.260: I/System.out(2991): ActivityA onCreate
    02-09 22:47:39.610: I/System.out(2991): ActivityA onStart
    02-09 22:47:39.610: I/System.out(2991): ActivityA onResume

  • 自动灭屏(锁屏)

    02-09 22:47:39.630: I/System.out(2991): ActivityA onPause
    02-09 22:47:39.770: I/System.out(2991): ActivityA onSaveInstanceState
    02-09 22:47:39.770: I/System.out(2991): ActivityA onStop

  • 按POWER键亮屏

    02-09 22:47:50.100: I/System.out(2991): ActivityA onRestart
    02-09 22:47:50.100: I/System.out(2991): ActivityA onStart
    02-09 22:47:50.140: I/System.out(2991): ActivityA onResume

  • 按POWER键灭屏

    02-09 22:49:40.860: I/System.out(2991): ActivityA onPause
    02-09 22:49:40.870: I/System.out(2991): ActivityA onSaveInstanceState
    02-09 22:49:40.870: I/System.out(2991): ActivityA onStop

  • 按BACK键退出

    02-09 22:50:14.650: I/System.out(2991): ActivityA onPause
    02-09 22:50:15.650: I/System.out(2991): ActivityA onStop
    02-09 22:50:15.650: I/System.out(2991): ActivityA onDestroy

  • 按HOME键回到launcher

    02-09 22:51:25.420: I/System.out(2991): ActivityA onPause
    02-09 22:51:26.090: I/System.out(2991): ActivityA onSaveInstanceState
    02-09 22:51:26.090: I/System.out(2991): ActivityA onStop

  • 长按HOME键点击最近使用的程序回到应用

    02-09 22:51:48.910: I/System.out(2991): ActivityA onRestart
    02-09 22:51:48.910: I/System.out(2991): ActivityA onStart
    02-09 22:51:48.910: I/System.out(2991): ActivityA onResume

  • 从ActivityA中点击进入ActivityB

    02-09 22:53:42.170: I/System.out(3158): ActivityA onPause
    02-09 22:53:42.210: I/System.out(3158): ActivityB onCreate
    02-09 22:53:42.670: I/System.out(3158): ActivityA onSaveInstanceState
    02-09 22:53:42.670: I/System.out(3158): ActivityA onStop

  • 从ActivityB按BACK键退回ActivityA

    02-09 22:54:49.320: I/System.out(3158): ActivityA onRestart
    02-09 22:54:49.320: I/System.out(3158): ActivityA onStart
    02-09 22:54:49.320: I/System.out(3158): ActivityA onResume

  • 在ActivityA中点击执行finish()方法

    02-09 22:55:28.110: I/System.out(3158): ActivityA onPause
    02-09 22:55:28.700: I/System.out(3158): ActivityA onStop
    02-09 22:55:28.700: I/System.out(3158): ActivityA onDestroy

  • 旋转屏幕

    02-09 22:59:28.030: I/System.out(3158): ActivityA onPause
    02-09 22:59:28.030: I/System.out(3158): ActivityA onSaveInstanceState
    02-09 22:59:28.030: I/System.out(3158): ActivityA onStop
    02-09 22:59:28.030: I/System.out(3158): ActivityA onDestroy
    02-09 22:59:28.050: I/System.out(3158): ActivityA onCreate
    02-09 22:59:28.220: I/System.out(3158): ActivityA onStart
    02-09 22:59:28.220: I/System.out(3158): ActivityA onRestoreInstanceState
    02-09 22:59:28.230: I/System.out(3158): ActivityA onResume

  • 在ActivityA中点击执行System.exit(0)
    no log

四、总结

onSaveInstanceState用于保存与界面有关的属性以便回到下次该界面时恢复状态,在当前Activity非“自愿”退出时调用,如GC回收内存、按HOME键 ,而BACK键与finish方法属于正常的退出界面的方法;而onRestoreInstanceState出现的场景更加苛刻,只有非手动直接造成Activity退出(暂时理解为执行了onDestory,有不对之处请指出),如旋转屏幕时、GC回收内存后,再次进入该Activity时,会调用该方法。

onSaveInstanceState & onRestoreInstanceState的更多相关文章

  1. 保存现场数据和状态:onSaveInstanceState\onRestoreInstanceState\onCreate()

    当某个activity变得“容易”被系统销毁时,该activity的onSaveInstanceState就会被执行,除非该activity是被用户主动销毁的,例如当用户按BACK键的时候. 注意上面 ...

  2. 【起航计划 012】2015 起航计划 Android APIDemo的魔鬼步伐 11 App->Activity->Save & Restore State onSaveInstanceState onRestoreInstanceState

    Save & Restore State与之前的例子Android ApiDemo示例解析(9):App->Activity->Persistent State 实现的UI类似,但 ...

  3. activity状态的保存和保持(onRetainNonConfigurationInstance和getLastNonConfigurationInstanc

    本文转载于:http://chengbs.iteye.com/blog/1156167 比较onsaveinstancestate() 与 onretainnonconfigurationinstan ...

  4. 5、四大组件之一-Activity与Intent

    一.Activity的定义及作用 1)官方定义:Activity是Android应用程序提供交互界面的一个重要组件 . 也是Android最重要的组件之一 2)Activity是业务类 , 是承载应用 ...

  5. 【转】Android Activity和Intent机制学习笔记----不错

    原文网址:http://www.cnblogs.com/feisky/archive/2010/01/16/1649081.html Activity Android中,Activity是所有程序的根 ...

  6. Android Activity和Intent机制学习笔记

    转自 http://www.cnblogs.com/feisky: Activity Android中,Activity是所有程序的根本,所有程序的流程都运行在Activity之中,Activity具 ...

  7. Android Intent机制与常见的用法

    Activity Android于.Activity所有的程序都是必不可少,程都执行在Activity之中.Activity具有自己的生命周期(见http://www.cnblogs.com/feis ...

  8. 知识树杂谈Android面试(3)

    一.Activity生命周期? a. Activity四种状态? Running.Paused(透明无焦点).Stopped.killed. b. OnStart() OnRusume区分? 是否可以 ...

  9. Android总结篇系列:Activity中几个主要函数详解

    Activity作为Android系统中四大基本组件之一,包含大量的与其他的各大组件.intent.widget以及系统各项服务等之间的交互的函数.在此,本文主要选取实际项目开发中常用的,但完全理解又 ...

随机推荐

  1. eclipse报错 :java was started but returned exit code=13

    一个礼拜没打开自己电脑上的eclipse,一打开居然报错,错误提示如下: cdm运行一下Java -version和javac 运行javac时报错,错误提示如下: 然后发现jdk的bin下没有dt. ...

  2. 常用vim设置

    set tabstop=4set shiftwidth=4set expandtabset hlsearchset cindent set autoindent set tabstop=4是设TAB宽 ...

  3. 单链表在不知头结点的情况下对第i个元素的删除

    一.首先,看看单链表中第i个元素的删除: Status ListDelete_L (LinkList &L,int i,ElemType &e){ //在带头结点的单链表L中,删除第i ...

  4. javascript对象属性的赋值解析

    代码如下: function Animal(){} function Dog (age){ this.name = 'fuck you' ; this.age = age } var dog = ne ...

  5. HIVE 启动出错总结

    1: [centos@centos4- bin]$ hive /home/centos/app/apache-hive--bin/bin/hive: line : /tmp/centos/stderr ...

  6. 利用 Gulp 处理前端工作流程

    最近做项目,因为每次做完后都要手动压缩CSS.JS 等文件,压缩后另存为 *.min.xxx. Less 还要手动输入命令进行编译,调整页面也经常要手动刷新页面看效果,很麻烦,就尝试用 gulp 去处 ...

  7. xtrabackup备份与恢复实践

    说明   xtrabackup  --percona 特点: 开源,在线备份innodb表 支持限速备份,避免对业务造成影响 支持流备 支持增量备份 支持备份文件压缩与加密 支持并行备份与恢复,速度快 ...

  8. 关于CacheLookup一个有趣的问题

    今天写一个与其他系统进行物料同步的接口,通过COM Business Connector调用Axapta3.0的方法将数据插入到物料表中,中间发生异常,事务回滚,再次调用的时候提示刚刚发生异常的物料已 ...

  9. cannot access the system temp folder

    cannot access the system temp folder. please, make sure your application have full control rights on ...

  10. spring注解和xml方式区别详解

    一.spring常规方式. 在使用注释配置之前,先来回顾一下传统上是如何配置 Bean 并完成 Bean 之间依赖关系的建立.下面是 3 个类,它们分别是 Office.Car 和 Boss,这 3 ...