Android程序完全退出步骤

方法A:

1.5版本到2.1版本的退出方法是

ActivityManager activityManager =  (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
activityManager.restartPackage("包名");

2.2版本必须把后台数据清空了:

步骤1:
/**
     * activityList:所有activity对象,用于退出时全部finish; Activity走onCreate时,添加到该集合
     */
    public static List<Activity> activityList = new ArrayList<Activity>();

步骤2:
/**
     * 页面初始化
     * 
     * @param savedInstanceState
     */
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
       activityList.add(this);

步骤3:
/**
     * 退出客户端。
     * 
     * @param context 上下文
     */
    public static void exitClient(Context context)
    {
        Log.d(TAG, "----- exitClient -----");
        // 关闭所有Activity
        for (int i = 0; i < activityList.size(); i++)
        {
            if (null != activityList.get(i))
            {
                activityList.get(i).finish();
            }
        }
        ActivityManager activityManager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
        activityManager.restartPackage("包路径");
        System.exit(0);//Android的程序只是让Activity finish()掉,而单纯的finish掉,退出并不完全
    }

这里要加System.exit(0);
还要记得加权限
<uses-permission android:name="android.permission.RESTART_PACKAGES" />

 

方法B:

android.os.Process.killProcess(android.os.Process.myPid());

归纳起来四种方法:

 

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());

  系统会将,该包下的 ,所有进程,服务,全部杀掉,就可以杀干净了,要注意加上权限

  3. 根据Activity的声明周期

  我们知道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 activityStack;
 
   private static ScreenManager instance;
 
   private ScreenManager(){
 
   }
 
   public static ScreenManager getScreenManager(){
 
   instance=new ScreenManager();
 
   }
 
   return instance;
 
   }
 
   //退出栈顶Activity
 
   public void popActivity(Activity activity){
 
   activity.finish();
 
   activityStack.remove(activity);
 
   activity=null;
 
   }
 
   }
 
   //获得当前栈顶Activity
 
   public Activity currentActivity(){
 
   Activity activity=activityStack.lastElement();
 
   return activity;
 
   }
 
   //将当前Activity推入栈中
 
   public void pushActivity(Activity activity){
 
   activityStack=new Stack();
 
   }
 
   activityStack.add(activity);
 
   }
 
   //退出栈中所有Activity
 
   public void popAllActivityExceptOne(Class cls){
 
   while(true){
 
   Activity activity=currentActivity();
 
   break;
 
   }
 
   break;
 
   }
 
   popActivity(activity);
 
   }
 
   }
 
   }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
随着人口老龄化和空巢化等社会问题的日益严峻,养老问题及以及养老方式的变革成为了当前社会的发展焦点,传统的养老模式以救助型和独立型为主,社会养老的服务质量与老年人的养老需求还存在一定的差距,人们生活水平的提高以及养老多元化需求的增加都需要通过创新和灵活开放的养老模式来应对未来的养老需求,结合目前我国养老模式及养老服务问题的内容的分析,互助养老模式作为一种新型的养老模式结合自主互助的集体养老理念,帮助老年人实现了满足个性需求的养老方案,互助养老模式让老年人具备了双重角色的同时也实现可持续的发展特色。目前我国老年人的占比以每年5%的速度在飞速增长,养老问题及养老服务的提供已经无法满足当前社会养老的切实需求,在养老服务质量和养老产品的变革过程中需要集合多元化的养老模式来满足更多老人的养老需求。 鉴于我国目前人口老龄化的现状以及迅速扩张的养老服务需求,现有的养老模式已经无法应对和满足社会发展的需求,快速增长的养老人员以及养老服务供给不足造成了紧张的社会关系,本文结合当前养老服务的发展需求,利用SSM框架以及JSP技术开发设计一款正对在线互助养老的系统,通过系统平台实现养老机构信息的传递及线上预约,搭建了起了用户、养老机构以及系统管理员的三方数据平台,借助网页端实现在线的养老互助信息查询、养老机构在线预约以及求助需求等功能,通过自养互养的养老模式来帮助老年人重新发现自我价值以及丰富养老的主观能动性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值