zoukankan      html  css  js  c++  java
  • android_onSaveInstanceState_onRestoreInstanceState研究

          当一个activity的状态是一个容易被系统宰掉时,比如pause或者stop状态,此时这个活动不一定已经被销毁了,那么这个activity的onSaveInstanceState方法会被系统调用(值得一试),上代码:

    package cn.com.sxp;

    import android.app.Activity;
    import android.os.Bundle;
    import android.util.Log;

    public class OnrestoreActivity extends Activity {
    private static final String TAG = OnrestoreActivity.class.getSimpleName();
    private int count = 0;
    private boolean thread;
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    if (null != savedInstanceState) {
    int preSavedInt = savedInstanceState.getInt("preSavedInt");
    String preSavedStr = savedInstanceState.getString("preSavedStr");
    Log.e(TAG, "onCreate we get prior preSavedInt is: " + preSavedInt
    + " and preSavedStr is: " + preSavedStr);
    }
    setContentView(R.layout.main);
    new Thread(new Runnable() {
    @Override
    public void run() {
    while (true) {
    if (!thread) {
    Log.v(TAG, Boolean.toString(thread));
    try {
    Thread.sleep(1000);
    } catch (Exception e) {
    e.printStackTrace();
    }
    count++;
    Log.v(TAG, "count : " + count);
    }
    }
    }
    }).start();
    }

    @Override
    // 为了防止万一程序被销毁的风险,这个方法可以保证重要数据的正确性
    // 不写这个方法并不意味着一定出错,但是一旦遇到了一些非常奇怪的数据问题的时候
    // 可以看看是不是由于某些重要的数据没有保存,在程序被销毁时被重置
    public void onSaveInstanceState(Bundle savedInstanceState) {
    savedInstanceState.putInt("preSavedInt", count);
    savedInstanceState.putString("preSavedStr", "we are saved in onSaveInstanceState");
    super.onSaveInstanceState(savedInstanceState);
    Log.e(TAG, "onSaveInstanceState");
    }

    @Override
    public void onRestoreInstanceState(Bundle savedInstanceState) {
    super.onRestoreInstanceState(savedInstanceState);
    int preCount = savedInstanceState.getInt("preSavedInt");
    String preStr = savedInstanceState.getString("preSavedStr");
    Log.e(TAG, "onRestoreInstanceState we get preCount is: " + preCount + " and preStr is: "
    + preStr);
    }

    public void onDestroy() {
    super.onDestroy();
    this.thread = true;
    }

    public void onPause() {
    Log.v(TAG, "onPause");
    super.onPause();
    thread = true;
    }

    public void onResume() {
    Log.v(TAG, "onResume");
    super.onResume();
    thread = false;
    }

    public void onStop() {
    Log.v(TAG,"onStop");
    super.onStop();
    this.thread = true;
    }
    }


    当活动onresume时打印日志如下:

     

    此时一切正常,没有调用onsave等方法;就这样我让这个线程跑了30多次,之后做了一个横竖屏切换,发生的日志如下:

     

    可以看到,此时活动即将转入onpause状态,在这之前系统调用了onsave方法,果然啊,系统怕在onpause时宰掉活动,所以调用该方法保存一些数据,后面才依次调用onpause和onstop方法。

    再看看,切换到竖屏后,活动被重新构建,果然此时活动就从之前保存的数据再读出来。oncreate后又调用了onrestore方法,之后才是正常的其他状态出马,继续恢复起线程的运行。

    好了,到这里我手痒,又按下了home键,日志打印如下:

    可以看到,与切换到竖屏是一样的效果。

    好吧,恢复这个程序的运行吧,日志如下:

     

     继续onresume。

    很强大。以上事例说明,我本人不想销毁,但是系统由于内存的原因或者其他什么原因不得不销毁,系统还不给我机会让我保存数据?倘若该activity被我主动宰掉的话,例如我闲的蛋疼按下BACK键,这个方法就不会被调用(值得一试)。

          先总结以下几点关于onSaveInstanceState方法被调用的场景:

          1、爷按下HOME键

               按下后,当然是home界面了,原来的应用程序当然不可见啦,应该是stop状态(以上已经测试);这就危险了,该活动可能被销毁,所以被调用(以上已经测试);

          2、按下电源按键(关闭屏幕显示)

              也就是我要待机了
          3、从一个活动activity启动第二个activity(没有测试)
          4、横竖屏切换(以上已经测试) 

     

          那还有一个onRestoreInstanceState方法呢。这个方法调用前提是,一个activity被创建了(以上已经测试)。因为一个activi被创建后,你哪知道它之前是呗销毁了还是没有被销毁的。当然啦,如果是被销毁的,那么onCreate与onRestoreInstanceState的bundle参数是一个参数吧(已经测试,输出是一样的)。

     

  • 相关阅读:
    手误【删库】 == 跑路,不存在的 Linux回收站
    大规模集群全网数据备份解决方案
    宝塔Nginx配置防盗链
    Markdown语法
    QFtp编程模型(二)
    Ubuntu驱动程序开发6-Linux内核启动与程序烧写
    Ubuntu下TFTP、NFS和SSH服务搭建
    ubuntu环境变量的三种设置方式
    QByteArray详解
    mysql的索引下推理解和实践
  • 原文地址:https://www.cnblogs.com/itblog/p/2281266.html
Copyright © 2011-2022 走看看