转载:

这里有两种方式退出Activity:

第一种:退出当前Activity:
   思路:记录当前时间,然后,当点击的时间与当前时间间隔小于三秒,则退出。

   方法:在要退出的Activity 添加如下代码:


private long time;    //记录当前时间
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
//如果两次按键时间间隔大于3秒,则不退出。
if ((System.currentTimeMillis() - time) > 3000) {
Toast.makeText(this, "再按一次退出", Toast.LENGTH_SHORT).show();
time = System.currentTimeMillis();
}else{
//System.exit(0);
finish();
}
return true;
}
return super.onKeyDown(keyCode, event);

}


第二种:退出多个Activity
         思路:写一个ExitActivityUtil 类,继承Application,然后在该类中添加所有Activity,然后在exit()方法里面直接退出。

package com.prismnetwork.util;

import java.util.LinkedList;
import java.util.List;

import android.app.Activity;
import android.app.Application;
/**
 * 该类用于完全退出整个App
 * @author Administrator
 *
 */
public class ExitActivityUtil extends Application{
List activityList = new LinkedList();//Activity 容器
private static ExitActivityUtil instance;
private ExitActivityUtil(){
}
/**
* 单例,获取唯一的ExitActivity 实例
*/
public static ExitActivityUtil getInstance(){
if (null == instance) {
instance = new ExitActivityUtil();
}
return instance;
}
/**
* 添加Activity 到容器中
* @param activity
*/
public void addActivity(Activity activity){
activityList.add(activity);
}
/**
* 遍历所有Activity 并退出
*/
public void exit(){
for(Activity activity : activityList){
activity.finish();
}
System.exit(0);
}
}

实现方法:

1. 写一个BaseActivity,继承自Activity。

2. 在OnCreate()方法里面添加ExitActivityUtil.getInstance().addActivity(this);  。

3. 在第一种方法的else{}语句中添加调用该工具类的exit()方法即可,即添加ExitActivityUtil.getInstance().exit();  。

更多相关文章

  1. Android(安卓)Intent的几种用法全面总结 --
  2. Android(安卓)widget桌面小部件与RemoteViewsService
  3. Android(安卓)5.1 Lollipop Phone工作流程浅析(十三)__InCallAct
  4. Android(安卓)Studio添加so文件并打包到APK的lib文件夹中
  5. Android(安卓)易忘部分
  6. Android再按一次返回键退出程序的实现
  7. RemoteViews用法一:widget简单用法
  8. 【070】Android(安卓)中相关功能的实现代码
  9. Android添加多语言

随机推荐

  1. SQL实现LeetCode(183.从未下单订购的顾客
  2. SQL实现LeetCode(182.重复的邮箱)
  3. SQL实现LeetCode(181.员工挣得比经理多)
  4. mysql表分区的使用与底层原理详解
  5. Mysql纵表转换为横表的方法及优化教程
  6. MYSQL使用Union将两张表的数据合并显示
  7. 一次mysql迁移的方案与踩坑实战记录
  8. SQL实现LeetCode(180.连续的数字)
  9. Mysql中where与on的区别及何时使用详析
  10. SQL实现LeetCode(178.分数排行)