Android退出應用最優雅的方式

一、容器式

來自:http://mp.weixin.qq.com/s?__biz=MzI0ODEwNzIxNg==&mid=2652656121&idx=1&sn=51696f4894068bdf19257216da3e0ec0&scene=0#wechat_redirect


    建立一個全局容器,把所有的Activity存儲起來,退出時循環遍歷finish所有Activity


import java.util.ArrayList;

import java.util.List;

import android.app.Activity;

import android.os.Bundle;

public class BaseActivity extends Activity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

// 添加Activity到堆棧

AtyContainer.getInstance().addActivity(this);

}

@Override

protected void onDestroy() {

super.onDestroy();

// 結束Activity&從棧中移除該Activity

AtyContainer.getInstance().removeActivity(this);

}

}

class AtyContainer {

private AtyContainer() {

}

private static AtyContainer instance = new AtyContainer();

private static List<Activity> activityStack = new ArrayList<Activity>();

public static AtyContainer getInstance() {

return instance;

}

public void addActivity(Activity aty) {

activityStack.add(aty);

}

public void removeActivity(Activity aty) {

activityStack.remove(aty);

}

/**

* 結束所有Activity

*/

public void finishAllActivity() {

for (int i = 0, size = activityStack.size(); i < size; i++) {

if (null != activityStack.get(i)) {

activityStack.get(i).finish();

}

}

activityStack.clear();

}

}


    這種方法比較簡單, 但是可以看到activityStack持有這Activity的強引用,也就是說當某個Activity異常退出時,activityStack沒有即使釋放掉引用,就會導致內存問題,接下來我們看一種類似的方式,但是會稍微優雅一點點.


二、廣播式


     通過在BaseActivity中註冊一個廣播,當退出時發送一個廣播,finish退出


public class BaseActivity extends Activity {

private static final String EXITACTION = "action.exit";

private ExitReceiver exitReceiver = new ExitReceiver();

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

IntentFilter filter = new IntentFilter();

filter.addAction(EXITACTION);

registerReceiver(exitReceiver, filter);

}

@Override

protected void onDestroy() {

super.onDestroy();

unregisterReceiver(exitReceiver);

}

class ExitReceiver extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent) {

BaseActivity.this.finish();

}

}

}

[size=12.0000pt]



輸入標題


    通過直接殺死當前應用的進程來結束應用,簡單粗暴,而且有(wu)效!


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

  2. System.exit(0);

  3. ActivityManager manager = (ActivityManager) getSystemService(ACTIVITY_SERVICE);

  4. manager.killBackgroundProcesses(getPackageName());


    這三種都能達到同樣的效果,但是在模擬器上都會彈出 Unfortunately , XXX has stopped 消息提示框,但確實能退出應用。部分真機直接失效,只能finish當前Activity(比如我手上這臺小米note,國產的幾款ROM fw層改動太多,使用這種方式需慎重) 。


四、 RS優雅式


    什麼是RS式呢?即Receiver+singleTask 。我們知道Activity有四種加載模式,而singleTask就是其中的一種,使用這個模式之後,當startActivity時,它先會在當前棧 中查詢是否存在Activity的實例,如果存在,則將其至於棧頂,並將其之上的所有Activity移除棧。我們打開一個app,首先是一個 splash頁面,然後會finish掉splash頁面。跳轉到主頁。然後會在主頁進行N次的跳轉,期間會產生數量不定的Activity,有的被銷 毀,有的駐留在棧中,但是棧底永遠是我們的HomeActivity。這樣就讓問題變得簡單很多了。我們只需兩步操作即可優雅的實現app的退出。


    1、在HomeActivity註冊一個退出廣播,和第二個廣播式一樣,但是這裏只需要在HomeActivity一個頁面註冊即可。


    2、設置HomeActivity的啓動模式爲singleTask。


    當我們需要退出的時候只需要startActivity(this,HomeActivity,class), 再發送一個退出廣播。上面代碼首先會把棧中HomeActivity之上的所有Activity移除出棧,然後接到廣播finish自己。一切OK ! 沒有彈框,不用考慮機型Rom適配。不會有內存問題,就是那麼的優雅,簡單!

發佈了28 篇原創文章 · 獲贊 1 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章