Android:进程运行中被收回权限

在这里插入图片描述

流程如图:

  • 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())
    }