zoukankan      html  css  js  c++  java
  • [Activity]直接退出应用的方法

    Android程序有很多Activity,比如说主窗口A,调用了子窗口B,如果在B中直接finish(), 接下里显示的是A。在B中如何关闭整个Android应用程序呢?本人总结了几种比较简单的实现方法。

    1. Dalvik VM的本地方法

    android.os.Process.killProcess(android.os.Process.myPid())    //获取PID
    System.exit(0);   //常规java、c#的标准退出法,返回值为0代表正常退出

    2. 任务管理器方法

    首先要说明该方法运行在Android 1.5 API Level为3以上才可以,同时需要权限

    ActivityManager am = (ActivityManager)getSystemService (Context.ACTIVITY_SERVICE);
    am.restartPackage(getPackageName());
    系统会将,该包下的 ,所有进程,服务,全部杀掉,就可以杀干净了,要注意加上
    <uses-permission android:name="android.permission.RESTART_PACKAGES"></uses-permission>

    3. 根据Activity的声明周期

    3.  我们知道Android的窗口类提供了历史栈,我们可以通过stack的原理来巧妙的实现,这里我们在A窗口打开B窗口时在Intent中直接加入标志     Intent.FLAG_ACTIVITY_CLEAR_TOP,这样开启B时将会清除该进程空间的所有Activity。

    在A窗口中使用下面的代码调用B窗口

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

    接下来在B窗口中需要退出时直接使用finish方法即可全部退出。

    4.自定义一个Actiivty 栈,道理同上,不过利用一个单例模式的Activity栈来管理所有Activity。并提供退出所有Activity的方法。代码如下:

    public class ScreenManager {
    private static Stack<Activity> activityStack;
    private static ScreenManager instance;
    private  ScreenManager(){
    }
    public static ScreenManager getScreenManager(){
    if(instance==null){
    instance=new ScreenManager();
    }
    return instance;
    }
    //退出栈顶Activity
    public void popActivity(Activity activity){
    if(activity!=null){
    activity.finish();
    activityStack.remove(activity);
    activity=null;
    }
    }

    //获得当前栈顶Activity
    public Activity currentActivity(){
    Activity activity=activityStack.lastElement();
    return activity;
    }

    //将当前Activity推入栈中
    public void pushActivity(Activity activity){
    if(activityStack==null){
    activityStack=new Stack<Activity>();
    }
    activityStack.add(activity);
    }
    //退出栈中所有Activity
    public void popAllActivityExceptOne(Class cls){
    while(true){
    Activity activity=currentActivity();
    if(activity==null){
    break;
    }
    if(activity.getClass().equals(cls) ){
    break;
    }
    popActivity(activity);
    }
    }
    }

  • 相关阅读:
    洛谷P2664 树上游戏(点分治)
    洛谷P3366 【模板】最小生成树(Boruvka算法)
    loj#2312. 「HAOI2017」八纵八横(线性基 线段树分治)
    noi.ac#309 Mas的童年(子集乱搞)
    loj#6041. 「雅礼集训 2017 Day7」事情的相似度(SAM set启发式合并 二维数点)
    Windows phone应用开发[22]-再谈下拉刷新
    Windows phone应用开发[21]-图片性能优化
    Windows phone应用开发[20]-禁止Pivot手势
    Windows phone应用开发[19]-RSA数据加密
    Windows phone应用开发[18]-下拉刷新
  • 原文地址:https://www.cnblogs.com/webapplee/p/3774037.html
Copyright © 2011-2022 走看看