APP完全退出

1. Dalvik VM的本地方法
  android.os.Process.killProcess(android.os.Process.myPid())    //获取PID
  System.exit(0);   //常规java、c#的标准退出法,返回值为0代表正常退出
在小米3中,只能关掉当前Activity,可能在其它android系统中可以,但至少说明不通用.

2.  我们知道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);

3. 任务管理器方法
   首先要说明该方法运行在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>
因为下不兼容,也不是很推荐。

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

整个应用的生命同期中维护一个List集合,极易产生内存堆积,处理不好就是内存堆积和溢出的现象,如果未关闭的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);
  }
 }
}

5.自定义广播实现app完全退出(推荐
    推荐用广播的方式去关闭整个应用程序,思路就是为所有的Activity创建一个父类,只要在父类中注册一个自定义关闭应用广播即可实现,仔细想了一下这个方法是可行的,只要在基类中动态注册一个广播就可实现这个功能.

代码如下

ExitAppReceiver:
package com.example.appexitdemo;
import android.app.Activity;
import android.app.Service;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.support.v4.app.FragmentActivity;
//自定义一个广播接收器,用来接收应用程序退出广播.
public class ExitAppReceiver extends BroadcastReceiver {
 @Override
 public void onReceive(Context context, Intent intent) {
  if (context != null) {
   if (context instanceof Activity) {
    ((Activity) context).finish();
   } else if (context instanceof FragmentActivity) {
    ((FragmentActivity) context).finish();
   } else if (context instanceof Service) {
    ((Service) context).stopSelf();
   }
  }
 }
}

BaseActivity:
package com.example.appexitdemo;
import android.app.Activity;
import android.content.IntentFilter;
import android.os.Bundle;
//应用程序中所有Activity的基类
public class BaseActivity extends Activity {
 private ExitAppReceiver exitReceiver = new ExitAppReceiver();
 // 自定义退出应用Action,实际应用中应该放到整个应用的Constant类中.
 private static final String EXIT_APP_ACTION = "com.micen.exit_app";
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  registerExitReceiver();
 }
 private void registerExitReceiver() {
  IntentFilter exitFilter = new IntentFilter();
  exitFilter.addAction(EXIT_APP_ACTION);
  registerReceiver(exitReceiver, exitFilter);
 }
 private void unRegisterExitReceiver() {
  unregisterReceiver(exitReceiver);
 }
 @Override
 protected void onDestroy() {
  super.onDestroy();
  unRegisterExitReceiver();
 }
 @Override
 protected void onStart() {
  super.onStart();
 }
 @Override
 protected void onStop() {
  super.onStop();
 }
}


在App退出方法中添加以下发送广播代码即可:
Intent intent = new Intent(); 
intent.setAction(EXIT_APP_ACTION);
sendBroadcast(intent);

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。