framework

App进程被回收问题总结

2017-08-20  本文已影响0人  楚灵彦

1. App在什么状态下被回收

Android系统在运行程序的过程中发现内存不足,他会去杀一些后台进程,来获取内存,这个过程我们简单称为回收进程。如果后台进程都杀光了,内存还不够,此时可能有2种表现,1,跳出OOM崩溃 2,杀死前台进程。并没有回收某个activity或者回收某些activity的行为。

2. Android的几种进程

3.避免后台进程被系统回收方法

4.后台进程被回收,进程重启下,Activity的恢复规则

进程被自然回收之后,Activity的栈信息,历史记录还存在。再从历史程序里点击的时候,进程会重启,然后只恢复栈顶的activity,其他栈内的activity只有在需要的时候被恢复。

5.其他形式的进程死亡再恢复

崩溃(比如空指针),ddms杀进程.

这2种方式杀进程之后的恢复和回收进程的不太一样。因为这2种方式导致进程死亡,此时进程一般是前台进程前台进程死亡,然后恢复并不会恢复栈顶activity,而是恢复栈顶前面的那个activity,为什么呢?
我们来解释下,如果是崩溃导致进程死亡,那崩溃发生在栈顶的那个activity,此activity根本没调用 onSaveInstanceState,那怎么恢复?没法恢复,只能恢复上一个activity。

6.进程恢复Activity规则

7.进程重启处理

在Application中定义一个static常量,赋值为-1,在欢迎界面改为0,如果被强杀,application重新初始化,在父类Activity判断该常量的值。

如果在每一个Activity的onCreate里判断是否被强杀,冗余了,封装到Activity的父类中,如果被强杀,跳转回主界面,如果没有被强杀,执行Activity的初始化操作,给主界面传递intent参数,主界面会调用onNewIntent方法,在onNewIntent跳转到欢迎页面,重新来一遍流程。

8.进程被强杀,是指System.exit(0),或者非系统回收而强制停止进程

上一篇 下一篇

猜你喜欢

热点阅读