关于Activity使用SingleTask,从home点击图标后清空栈的问题

问题背景

如果从桌面启动的MainActivity的launchMode=SingleTask,那么当app调用其他的Activity时,用户回到home键回到桌面,再次进入App时,原来的界面会消失,直接显示在来MainActivity所在的页面

Activity的四种运行模式

Standard

  • 默认模式,允许多个Activity实例

SingleTop

  • 相比于standard,有新的启动请求时,只有在目标Activity处于当前栈顶时,才会调用onNewIntent()而不创建新实例,其他情况都和standard一致

SingleTask

  • 设置了singleTask启动模式的Activity,它在启动的时候,会先在系统中查找属性值affinity等于它的属性值taskAffinity的任务存在;如果存在这样的任务,它就会在这个任务中启动,否则就会在新任务中启动。因此,如果我们想要设置了singleTask启动模式的Activity在新的任务中启动,就要为它设置一个独立的taskAffinity属性值。如果设置了singleTask启动模式的Activity不是在新的任务中启动时,它会在已有的任务中查看是否已经存在相应的Activity实例,如果存在,就会把位于这个Activity实例上面的Activity全部结束掉,即最终这个Activity实例会位于任务的堆栈顶端中。

SingleInstance

  • singleTask相比,不同点在于singleInstance activity所在的task只会有这一个activity

原理分析

按照我们应用的启动流程,首先进入的是MainActivity,这个时候再次进入一个其他的Activity,那么我们回到用户桌面,再次进入App,这个流程图大致是:

start MainActivity -> 首页 -> 进入另外一个XActivity,从桌面进入App -> MainActivity

  • 那么这个时候XActivity和MainActivity在同一个任务栈并且XActivity是在MainActivity之上
  • 当我们再次从桌面进入App的时候,这个时候系统会调用Launch属性的MainActivity,由于MainActivity是SingleTask会进行清除在其之上的Activity,将自己置于栈顶

所以我们再次进入App后,原先进入的Activity页面不见了而显示了首页,就是因为MainActivity的SingleTask会进行清除其之上的Activity

解决办法

双Activity

  • 将LaunchActivity用做桥梁的作用,启动后将自己finish,每次启动App的时候LaunchActivity都是处于栈顶,而不是直接startMainActivity