Android開發學習筆記:Activity的生命週期淺析

1.Android系統中Activity做爲Activity棧(Stack)被管理的,你們都知道棧的特色是先進後出,因此當前活動的Activity處於棧頂,以前非活動的Activity被壓入棧底,等待是否可能被恢復爲活動狀態。java

Android API中所提供的Activity生命週期圖:android

2.下面的整個Activity生命週期中的全部方法,咱們能夠根據程序的須要來覆蓋相應的方法:app

  
  
           
  
  
  1. public class Activity extends ApplicationContext {  
  2.        //建立的時候調用  
  3.        protected void onCreate(Bundle savedInstanceState);  
  4.        //啓動的時候調用  
  5.        protected void onStart();     
  6.        //從新啓動的時候調用  
  7.        protected void onRestart();  
  8.        //恢復的時候調用  
  9.        protected void onResume();  
  10.        //暫停的時候調用  
  11.        protected void onPause();  
  12.        //中止的時候調用  
  13.        protected void onStop();  
  14.        //銷燬的時候調用  
  15.        protected void onDestroy();  
  16.    } 

 ide

onCreate(Bundle savedInstanceState):建立activity時調用。設置在該方法中,還以Bundle的形式提供對之前儲存的任何狀態的訪問!
onStart():activity變爲在屏幕上對用戶可見時調用。
onResume():activity開始與用戶交互時調用(不管是啓動仍是從新啓動一個活動,該方法老是被調用的)
onPause():activity被暫停或收回cpu和其餘資源時調用,該方法用於保存活動狀態的,也是保護現場,壓棧。
onStop():activity被中止並轉爲不可見階段及後續的生命週期事件時調用。
onRestart():從新啓動activity時調用。該活動仍在棧中,而不是啓動新的活動
onDestroy():activity被徹底從系統內存中移除時調用

3.下面經過實例來測試Activity的生命週期中各個方法的調用狀況,將Activity的全部方法都覆蓋,主要用Log打印輸出信息,並經過日誌(LogCat)方式來觀察運行結果。Log.v(String tag, String msg); //Verbose
Log.d(String tag, String msg);  //Debug
Log.i(String tag, String msg); //Info
Log.w(String tag, String msg); //Warning
Log.e(String tag, String msg); //Error

tag相似標籤,能夠是任意字符串,一般可使用類名+方法名, 主要是用來在查看日誌時提供一個篩選條件。測試

下面的實例是測試Activity的生命週期中各個方法的調用狀況:this

MainActivity.javaspa

  
  
           
  
  
  1. package com.android.TestAvtivity.activity;  
  2.  
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.util.Log;  
  6. import android.view.View;  
  7. import android.view.View.OnClickListener;  
  8. import android.widget.Button;  
  9.  
  10. public class MainActivity extends Activity {  
  11.       
  12.     private Button btn;  
  13.     private static final String TAG="MainActivity";  
  14.     @Override 
  15.     public void onCreate(Bundle savedInstanceState) {  
  16.         super.onCreate(savedInstanceState);  
  17.         setContentView(R.layout.main);  
  18.         //輸出日誌  
  19.         Log.i(TAG, "MainActivity onCreate--->");  
  20.         btn = (Button)findViewById(R.id.Button1);  
  21.         btn.setOnClickListener(new OnClickListener() {  
  22.             @Override 
  23.             public void onClick(View v) {  
  24.                 //結束當前的Activity  
  25.                 MainActivity.this.finish();  
  26.             }  
  27.         });  
  28.     }  
  29.       
  30.     @Override 
  31.     //啓動  
  32.     protected void onStart() {  
  33.         super.onStart();  
  34.         //輸出日誌信息  
  35.         Log.i(TAG, "MainActivity onStart--->");  
  36.     }  
  37.       
  38.     @Override 
  39.     //重啓  
  40.     protected void onRestart() {  
  41.         super.onRestart();  
  42.         //輸出日誌信息  
  43.         Log.i(TAG, "MainActivity onRestart--->");  
  44.     }  
  45.       
  46.     @Override 
  47.     //恢復  
  48.     protected void onResume() {  
  49.         super.onResume();  
  50.         //輸出日誌信息  
  51.         Log.i(TAG, "MainActivity onResume--->");  
  52.     }  
  53.       
  54.     @Override 
  55.     //暫停  
  56.     protected void onPause() {  
  57.         super.onPause();  
  58.         //輸出日誌信息  
  59.         Log.i(TAG, "MainActivity onPause--->");  
  60.     }  
  61.       
  62.     @Override 
  63.     //中止  
  64.     protected void onStop() {  
  65.         super.onStop();  
  66.         //輸出日誌信息  
  67.         Log.i(TAG, "MainActivity onStop--->");  
  68.     }  
  69.       
  70.     @Override 
  71.     //銷燬  
  72.     protected void onDestroy() {  
  73.         super.onDestroy();  
  74.         //輸出日誌信息  
  75.         Log.i(TAG, "MainActivity onDestroy--->");  
  76.     }   

main.xml日誌

  
  
           
  
  
  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:orientation="vertical" 
  4.     android:layout_width="fill_parent" 
  5.     android:layout_height="fill_parent" 
  6.     > 
  7.     <TextView   
  8.         android:id="@+id/TextView01"   
  9.         android:layout_width="wrap_content"   
  10.         android:layout_height="wrap_content"   
  11.         android:text="測試Activit生命週期" 
  12.         /> 
  13.     <Button   
  14.         android:id="@+id/Button1"   
  15.         android:layout_width="wrap_content"   
  16.         android:layout_height="wrap_content"   
  17.         android:text="關閉Activity" 
  18.         /> 
  19. </LinearLayout> 

效果圖:xml

 ①當啓動程序時,日誌的輸出結果以下圖所示,程序執行了onCreate()->onStart()->onResume三個方法。輸出以下:blog

MainActivity onCreate--->

MainActivity onStart--->

MainActivity onResume---> 

注意:這裏我是在選擇了綠色的「+」,這時出現了下圖的界面,以後我就在Filter Name上寫入Test,by Log Tag上寫入MainActivity,按OK保存,這時就能在LogCat上面篩選咱們想要看到的信息了。

②當按(返回鍵)或者按鈕時,日誌的輸出結果以下圖所示,程序前後調用了onPause( )->onStop( )->onDestory( )三個方法。

③當按(Home鍵)時,日誌的輸出結果以下圖所示,程序前後調用了onPause( )->onStop( )這兩個方法,這時候應用程序並無銷燬。

 ④當再次啓動程序時,日誌的輸出結果以下圖所示,程序前後調用了onRestart( )->onStart( )->onResume( )三個方法。

 

相關文章
相關標籤/搜索