編輯:Android開發實例
1、完整生命周期
上圖是Android Activity的生命周期圖,其中Resumed、Paused、Stopped狀態是靜態的,這三個狀態下的Activity存在時間較長。
(1)Resumed:在此狀態時,用戶可以與Activity進行交互,Activity在最前端
(2)Paused:在此狀態時,Activity被另外一個Activity遮蓋,此Activity不可接受用戶輸入信息。另外一個Activity來到最前面,半透明的,但並不會覆蓋整個屏幕。
(3)Stopped:在此狀態時,Activity完全被隱藏,不可見。保留當前信息,Activity不執行任何代碼。
(4)Created與Started:系統調用onCreate()後迅速調用onStart(),然後迅速執行onResume()。
以上就是Android的Activity整個生命周期。
2、主Activity
用戶可以指定程序啟動的主界面,此時被聲明為“launcher或main”Activity的onCreate()方法被調用,成為程序的入口函數。該入口Activity可以在AndroidManifest.xml中定義主Activity。此時,主Activity必須使用以下標簽聲明:
代碼如下:
<activity android:name=".MainActivity" android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
3、一個新的Activity實例
系統首先調用新Activity的onCreate()方法,所以,我們必須實現onCreate()方法。如:聲明UI元素、定義成員變量、配置UI等。但是事情不宜太多,避免啟動程序太久而看不到界面。
代碼如下:
TextView mTextView; // Member variable for text view in the layout
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Set the user interface layout for this Activity
// The layout file is defined in the project res/layout/main_activity.xml
file
setContentView(R.layout.main_activity);
// Initialize member TextView so we can manipulate it later
mTextView = (TextView) findViewById(R.id.text_message);
// Make sure we're running on Honeycomb or higher to use ActionBar APIs
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
// For the main activity, make sure the app icon in the action bar
// does not behave as a button
ActionBar actionBar = getActionBar();
actionBar.setHomeButtonEnabled(false);
}
}
onCreate()執行完即調用onStart()和onResume()方法,Activity不會在Created或者Started狀態停留。
4、銷毀Activity
Activity的最後一個回調是onDestroy(),系統會執行這個方法做為你的Activity要從系統中完全刪除的信號。大多數APP不需實現此方法,因為局部類的references會隨著Activity的銷毀而銷毀。並且Activity應該在onPause()和onStop()方法中執行清楚Activity資源的操作。如果Activity在onCreate()時創建的後台線程,或者是其他有可能導致內存洩露的資源,你應該在onDestroy()時殺死它們。
代碼如下:
@Override
public void onDestroy() {
super.onDestroy(); // Always call the superclass
// Stop method tracing that the activity started during onCreate()
android.os.Debug.stopMethodTracing();
}
系統通常是在執行了onPause()與onStop()後在調用onDestroy(),除非在onCreate()中調用了finish()。例如,如果你的Activity只是做了一個臨時的邏輯跳轉功能,它使用用來決定跳轉到下一個Activity,這樣,你需要在onCreate()中調用finish()方法。系統就會直接調用onDestroy方法,其他生命周期就不會被執行。
5、暫停與恢復
當前Activity被其它可見組件阻塞,當前Activity部分可見,當前Activity進入Pause狀態。系統調用Activity中的onPause()方法,執行onResume()方法恢復。
當前Activity被其它組件完全阻塞,當前Activity完全不可見,則當前Activity進入Stop狀態。
當系統調用你的Activity中的onPause(),從技術上講,那意味著你的Activity仍然處於部分可見的狀態。通常在onPause()回調方法裡面做下面的事情。
(1)停止動畫或者其他正在運行的操作,減少CPU浪費
(2)提交沒有保存的改變,但僅僅是用戶離開時保存的內容,如郵件
(3)釋放系統資源,如broadcast receivers、sensors、GPS或者其他任何影響電量的資源。
(4)如果程序正在使用Camera,onPause()會是一個比較好的地方去釋放資源的操作。
代碼如下:
@Override
public void onPause() {
super.onPause(); // Always call the superclass method first
// Release the Camera because we don't need it when paused
// and other activities might need to use it.
if (mCamera != null) {
mCamera.release()
mCamera = null;
}
}
通常,不應該使用onPause()來保存用戶改變的數據到永久存儲上,當你確認用戶期待那些改變能夠自動保存的時候,才可以把那些數據存儲到永久存儲。然而,應該避免在onPause()時執行CPU-intensive的工作,例如寫數據到DB,因為他會導致切換Activity變得緩慢。這些工作應該放到onStop()中去坐。
如果,Activity實際上要被Stop,那麼應減少在onPause中的工作量,提高流暢性。
恢復Activity
用戶從Pause狀態恢復時,調用onResume()方法。此時Activity處於最前台,包括第一次創建時,此時,應該在onResume中初始化那些你在onPause方法裡釋放掉的組件,並執行那些Activity每次進入Resumed state都需要的初始化動作。
代碼如下:
@Override
public void onResume() {
super.onResume(); // Always call the superclass method first
// Get the Camera instance as the activity achieves full user focus
if (mCamera == null) {
initializeCamera(); // Local method to handle camera init
}
}
6、停止與重啟Activity
恰當的停止與重啟Activity會使用戶感知程序的進行。下面一些場景涉及停止與重啟:
(1)用戶打開最近使用的App的菜單並切換到另外一個App,此時,你的App是被停止的,用戶回到你的App,那麼你的Activity被重啟。
(2)用戶在App中啟動一個新的Activity的操作,當前Activity會在新Activity創建後stop,如果用戶點擊back按鈕,回到上一個Activity,重啟
(3)用戶使用App,接到來電時。
停止狀態UI不可見。系統在Activity停止時會在內存中保存了Activity實例,有時不需事先onStop(),onRestart()甚至onStart()方法,因為大多數的activity相對簡單,activity會自己停止與重啟。你只需要使用onPause來停止正在運行的動作,並斷開系統資源鏈接。
上圖顯示:當用戶離開你的Activity,系統會調用onStop()來停止Activity,用戶返回時調用onRestart(),然後迅速調用onStart()與onResume(),無論什麼原因導致Activity停止,系統總會在onStop之前調用onPause
停止Activity
當你的Activity調用onStop方法,Activity不再可見,並且應該釋放那些不再需要的所有資源,一旦你的Activity停止了,系統會在不需要的這個activity時銷毀它的實例。在極端情況下,系統會直接殺死你的App進程,並且不執行Activity的onDestroy()回調函數,因此你需要在onStop()來釋放資源,否則內存洩露。盡管onPause方法在onStop之前調用,應應該使用onStop來執行CPU-intensive的shut-down操作。如寫數據到DB。
當Activity停止,其對象會保存在內存中,並且在Resume時重新調用,不需在恢復到Resumed state狀態前初始化那些被保存在內存中得組件,系統為我們保存了每一個在布局中的視圖的當前狀態。即使系統會在Activity stop時銷毀這個Activity,它仍然會保存View對象的狀態到一個Bundle中,並且在用戶返回這個Activity時恢復他們。
重新創建Activity:當Activity在屏幕被旋轉時,會被destroy與recreated。此時會加載一些alternative的資源,如layout。默認情況下,系統使用Bundle實例來保存每一個視圖對象中得信息。為了使Android系統能夠恢復Activity中的View狀態,每個View都必須有一個唯一的ID
為了確保額外更多的數據到saved instance state,在Activity的聲明周期裡面存在一個添加的回調函數,必須重寫onSaveInstanceState(),當用戶離開你的Activity時,系統會調用它。當系統調用這個函數時,系統會在你的Activity被一場Destroy時傳遞Bundle對象,這樣,你可以增加額外的信息到Bundle中,並保存在系統中。如果系統在Activity被Destroy之後想重新創建這個Activity實例時,之前的那個Bundle對象會被傳遞到Activity的onRestoreInstanceState()方法和onCreate()方法中。
保存Activity狀態:當Activity開始Stop時,系統會調用onSaveInstanceState(),因此你的Activity可以用鍵值對的集合來保存狀態信息,這個方法會默認保存Activity視圖的狀態信息,例如在EditText組件中得文本或者是ListView的滑動位置。為了給Activity保存額外的狀態信息,你必須實現onSaveInstanceState()並增加鍵值對到Bundle中。如:
代碼如下:
static final String STATE_SCORE = "playerScore";
static final String STATE_LEVEL = "playerLevel";
...
@Override
public void onSaveInstanceState(Bundle savedInstanceState) {
// Save the user's current game state
savedInstanceState.putInt(STATE_SCORE, mCurrentScore);
savedInstanceState.putInt(STATE_LEVEL, mCurrentLevel);
// Always call the superclass so it can save the view hierarchy state
super.onSaveInstanceState(savedInstanceState);
}
恢復Activity狀態:當你的Activity從Destroy中重建,你可以從系統傳遞給你的Activity的Bundle中恢復保存的狀態。onCreate()與onRestoreInstanceState()回調方法都接收到了同樣的Bundle,裡面包含同樣的實例狀態信息。因為onCreate()方法會在第一次創建新的Activity實例與重新創建之前被Destroy的實例時都被調用,你必須嘗試讀取Bundle對象之前檢查它是否為NULL,如果為NULL,系統第一次創建新Activity。否則是恢復被Destroy的Activity。
代碼如下:
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); // Always call the superclass first
// Check whether we're recreating a previously destroyed instance
if (savedInstanceState != null) {
// Restore value of members from saved state
mCurrentScore = savedInstanceState.getInt(STATE_SCORE);
mCurrentLevel = savedInstanceState.getInt(STATE_LEVEL);
} else {
// Probably initialize members with default values for a new instance
}
...
}
我們可以選擇實現onRestoreInstanceState(),而不是在onCreate方法裡恢復數據。onRestoreInstanceState()方法會在onStart()方法之後執行,系統僅僅會在存在需要恢復的狀態信息時才會調用onRestoreInstanceState(),因此不需檢查Bundle是否為NULL。
代碼如下:
public void onRestoreInstanceState(Bundle savedInstanceState) {
// Always call the superclass so it can restore the view hierarchy
super.onRestoreInstanceState(savedInstanceState);
// Restore state members from saved instance
mCurrentScore = savedInstanceState.getInt(STATE_SCORE);
mCurrentLevel = savedInstanceState.getInt(STATE_LEVEL);
}
實現定時器有很多種方式,在這裡我簡單的介紹幾種方式 (1)使用Handler + Runnable的方式 代碼如下: Handler handler = new
登錄應用程序的屏幕,詢問憑據登錄到一些特定的應用。可能需要登錄到Facebook,微博等本章介紹了,如何創建一個登錄界面,以及如何管理安全問題和錯誤嘗試。首先,必須定義兩
最近一直在調用微信的API,卻發現一直調用不成功,糾結了好久,各方面找教程,找官方,官方裡的文檔也只是寫得很模糊,說是按三步走。 1、申請App_ID
如上一節中所講的那樣創建了ApiDemo工程後,我們就可以進行每個示例代碼的分