今天做项目发现一个问题,如题:
原因是:
以前在manifest.xml中加了 android:configChanges="orientation|keyboardHidden|navigation ,导致 activity并不会重新创建。
<activity android:name=".activity.EventsActivity" android:configChanges="orientation|keyboardHidden|navigation"/>
备注:
onsaveinstancestate() 讲解
在当前的activity中通过新的intent启动其它activities之后,它将通过这个方法自动保存自身的数据,当再次出返回时可以通过 onrestoreinstancestate()复原数据。另外一种情况也将调用这个方法,当旋转设备后屏幕显示模式发生改变时。需要注意的一点是整个过程完全由系统控制,无法通过onsaveinstancestate()返回一个自定义的数据。
另外,onsaveinstancestate()在所有activity destroying过程中被调用,它仅仅是为了在重新回到这个特定的activity之后,依据activity state重新创建一个与之前状态完全相同的activity。例如:当我们启动某些connection时,state并不能依然保存这个连接状态。所以当调用onsaveinstancestate后,所有当前的connection将一同销毁。当第二次通过 onrestoreinstancestate()找回之前的连接设置并重新建立新的连接实体。
onretainnonconfigurationinstance() 讲解
当device configuration发生改变时,将伴随destroying被系统调用。通过这个方法可以像onsaveinstancestate()的方法一样保留变化前的activity state,最大的不同在于这个方法可以返回一个包含有状态信息的object,其中甚至可以包含activity instance本身。新创建的activity可以继承大量来至于parent activity state信息。
用这个方法保存activity state后,通过getlastnonconfigurationinstance()在新的activity instance中恢复原有状态。
这个方法最大的好处是:
* 当activity曾经通过某个网络资源得到一些图片或者视频信息,那么当再次恢复后,无需重新通过原始资源地址获取,可以快速的加载整个activity状态信息。
* 当activity包含有许多线程时,在变化后依然可以持有原有线程,无需通过重新创建进程恢复原有状态。
* 当activity包含某些connection instance时,同样可以在整个变化过程中保持连接状态。
下边是需要特别注意的几点:
* onretainnonconfigurationinstance()在onsaveinstancestate()之后被调用。
* 调用顺序同样介于onstop() 和 ondestroy()之间。
参考资料: