如果已经启动了四个Activity:A,B,C和D。在D Activity里,我们要跳到B Activity,同时希望C finish掉,可以在startActivity(intent)里的intent里添加flags标记,如下所示:

Intent intent = new Intent(this, B.class);
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(intent);

这样启动B Activity,就会把D,C都finished掉,如果你的B Activity的启动模式是默认的(multiple) ,则B Activity会finished掉,再启动一个新的Activity B。  如果不想重新再创建一个新的B Activity,则在上面的代码里再加上:

intent.addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP); 

这样B Activity就会再创建一个新的了,而是会重用之前的B Activity,同时调用B Activity的onNewIntent()方法。

问题:
多activity中退出整个程序,例如从A->B->C->D,这时我需要从D直接退出程序。

网上资料:{
finish()和system(0)都只能退出单个activity。杀进程等的等方式都不行~~~
解决问题:
我们知道Android的窗口类提供了历史栈,我们可以通过stack的原理来巧妙的实现,这里我们在D窗口打开A窗口时在Intent中直接加入标志Intent.FLAG_ACTIVITY_CLEAR_TOP,再次开启A时将会清除该进程空间的所有Activity。
在D中使用下面的代码:

Intent intent = new Intent();
intent.setClass(D.this, A.class);
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); //注意本行的FLAG设置
startActivity(intent);
finish();

关掉自己
在A中加入代码:

Override
protected void onNewIntent(Intent intent) {
// TODO Auto-generated method stub
super.onNewIntent(intent);
//退出
if ((Intent.FLAG_ACTIVITY_CLEAR_TOP & intent.getFlags()) != ) {
finish();
}
}

A的Manifest.xml配置成android:launchMode="singleTop"

原理总结:
一般A是程序的入口点,从D起一个A的activity,加入标识Intent.FLAG_ACTIVITY_CLEAR_TOP这个过程中会把栈中B,C,都清理掉。因为A是android:launchMode="singleTop"
不会调用oncreate(),而是响应onNewIntent()这时候判断Intent.FLAG_ACTIVITY_CLEAR_TOP,然后把A finish()掉。
栈中A,B,C,D全部被清理。所以整个程序退出了。

最新文章

  1. Ruby 方法
  2. jQuery MiniUI开发系列之:安装部署
  3. javascript之简单的选择排序法
  4. xargs命令
  5. 每天一个linux命令(18):find 命令概览
  6. JavaWeb学习记录(十七)——JSP九大隐式对象
  7. 剑指Offer36 数字在排序数组中出现的次数
  8. RunLoop学习总结
  9. 三星Galaxy s4(i9505)得到完美root权限教程
  10. Flutter之CustomView
  11. docker的安装和升级
  12. ubuntu终端
  13. Spark菜鸟记录
  14. 2-Twentieth Scrum Meeting-20151220
  15. Codeforces Round #337 (Div. 2) C. Harmony Analysis
  16. [SDOI2014]数数
  17. jdk重装后com.sun.tools.javac.Main is not on the classpath的问题 .
  18. Python Django 之 Template 模板的使用
  19. 【NOI2014】【BZOJ3669】【UOJ#3】魔法森林
  20. 【NIFI】 实现数据库到数据库之间数据同步

热门文章

  1. crontab简易入门
  2. p4555&bzoj2565 最长双回文串
  3. es6基础系列四--字符串的拓展
  4. fs-hasher工具介绍
  5. 百度AI图片识别
  6. 2017乌鲁木齐区域赛K(容斥原理【求指定区间内与n互素的数的个数】)
  7. BZOJ 1858【线段树】
  8. Unity技术支持团队性能优化经验分享
  9. [Xcode 实际操作]四、常用控件-(7)UIStepper控件的使用
  10. HTML 常用头部标签(meta)