流程如图:
- MainActivity 跳转至 MainActivity2 再跳转至 MainActivity3MainActivity3
- 跳转至 设置,收回权限
- 一路返回
运行log如下
// 一路跳转,打开设置,收回权限
com.miss.soullink E/MainActivity: == onCreate == 25149
com.miss.soullink E/MainActivity: == onCreate == savedInstanceState null
com.miss.soullink E/MainActivity2: == onCreate == 25149
com.miss.soullink E/MainActivity3: == onCreate == 25149
// 返回时的
com.miss.soullink E/MainActivity3: == onCreate == 27596
com.miss.soullink E/MainActivity2: == onCreate == 27596
com.miss.soullink E/MainActivity3: == onDestroy == MainActivity3
com.miss.soullink E/MainActivity: == onCreate == 27596
com.miss.soullink E/MainActivity: == onCreate == savedInstanceState Bundle[{android:viewHierarchyState=Bundle[mParcelledData.dataSize=944], androidx.lifecycle.BundlableSavedStateRegistry.key=Bundle[{}], android:lastAutofillId=1073741823, android:fragments=android.app.FragmentManagerState@6d44964}]
com.miss.soullink E/MainActivity2: == onDestroy == MainActivity2
进程重启原因
权限收回后进程的id发生了变化,即运行中的程序在权限被收回后会强制重启,并记录了响应的activity栈信息。MainActivity2的onCreate方法在MainActivity3的onCreate后面调用,虽然activity的顺序得到了保存,但这是一个不安全的进程。好多初始化工作或者信息传递得不到保证!!
后面了解iOS机制,运行的iOS进程被收回权限后会重启进程但不会自动回到关闭时的页面,但Android却会!
进程重启后的处理
为保证进程的安全性,在系统重启app进程后,我们决定再次重启进程并回到登录界面。即权限收回后app重启进程两次
判断条件:因系统关闭进程属于异常关闭,savedInstanceState不为空,以此做判断进行二次重启进程。为保证安全性,可以把已有的权限做下对比与之前的权限做下对比,增强代码的健壮性。
除了权限收回还有别的情况也会导致进程异常关闭,多一层判断,少被领导干~
// 杀死并重启进程
fun restartApp(context: Context) {
val intent = context.packageManager.getLaunchIntentForPackage(context.packageName)
val restartIntent = PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_ONE_SHOT)
// 设置杀死应用后1秒重启
val mgr: AlarmManager = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager
mgr.set(AlarmManager.RTC, System.currentTimeMillis() + 1000, restartIntent)
// 重启应用
android.os.Process.killProcess(android.os.Process.myPid())
}
到此这篇关于Android进程运行中权限被收回导致关闭的问题解决的文章就介绍到这了,更多相关Android 权限收回内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!