想必安卓用户都遇到过系统弹出应用被强制关闭的情况, 这时候的用户体验是及其差的, 所以要极力避免, 当然造成应用被强关的情况有很多, 有因为空指针的, 还有异常未被捕获的, 内存泄露, 堆栈溢出等
今天我们来着重聊一下关于应用在后台由于内存不足被强杀, 用户手动返回前台导致Crash的解决方案.
如何解决这个问题, 就需要了解这个问题是如何产生的, 只有这样, 我们才能有针对的解决办法.
问题重现: 首先在CustomApplication中定义了一个静态变量, 然后再MainActivity中进行了初始化, 由SecondActivity调用. 当用户在SecondActivity中时点击home键, 应用进入后台, 一段时间后被系统forcekill, 这个时候, 所有变量均会被回收, 但是Back Stack(返回栈, 用来存储Activity)信息仍然会保留, 这点及其坑爹.如果此时用户通过任务管理器返回应用, 由于SecondActivity中调用了CustomApplication中定义的静态变量, 此时为null, 所以就发生了NullPointerException, 导致了应用Crash.
到这里, 就可以对症下药了!
solution1:
既然调用的变量可能为null, 那么我们可以判断该变量是否为null, 如果为null, 则再重新实例化. 但是,这里如果这个变量值必须从其它页面获取, 或者协同开发时这是另一个同事写的, 那就会变得很麻烦, 所以说这种不可取.
solution2:
单例模式, 同上!
solution3:
如果应用被前杀后, 走OnCreate()->OnRestart()->OnStart()->OnResume(),只要我们在OnCreate()之前判断是否应用被强杀即可. 如果被强杀, 重新启动Welcome页, 进而正常启动, 但这里我们就要将MainActivity的launchMode设置为singleTask或者singleTop, flag为clear_top.
具体过程: 在BaseActivity(Activity基类)判断是否被强杀, 如果是, 启动MainActivity,然后判断是否被强杀, 若果是, 启动HomeActivity并finish自己!
solution 3a:
或者创建一个ActivityManager类, 若被强杀, 启动HomeActivity后finish掉其它所有Activity.
优化:
创建一个应用状态管理类, 独立完成这里任务, 解耦!