基礎總結之Activity

来源:http://www.cnblogs.com/Daniel-android/archive/2016/09/15/5874964.html
-Advertisement-
Play Games

一、萬事開頭的序 網上看見大牛們的博客寫的那樣精彩,各種羡慕之情溢於言表。幾次衝動均想效仿牛人寫些博客來記錄下自己的心得體會,但均無感亦或是感覺容易被噴,相信很多菜鳥和我一樣都有過這樣的擔憂。萬事開頭難,不逼一下自己怎麼知道自己能不能飛起來。由於本人處於初學階段,寫此博客僅是對前輩總結的review ...


一、萬事開頭的序

  網上看見大牛們的博客寫的那樣精彩,各種羡慕之情溢於言表。幾次衝動均想效仿牛人寫些博客來記錄下自己的心得體會,但均無感亦或是感覺容易被噴,相信很多菜鳥和我一樣都有過這樣的擔憂。萬事開頭難,不逼一下自己怎麼知道自己能不能飛起來。由於本人處於初學階段,寫此博客僅是對前輩總結的review,對自己記憶的加深及後續使用的方便查找。請各位看官將就看看,手下留情。在此謝過!有錯的地方或者更好的心得體會歡迎隨時騷擾!

二、Activity介紹

Android中常說的四大組件包括:Activity、Service、Broadcast、Content Provider

其中最基礎也是最常見的就是今天review的主題:Activity

Activity存在的意義:用戶與Android系統的交互的途徑

三、Activity的生命周期

老套路先上經典的生命周期圖:

(1)正常情況下的生命周期

Activity的生命周期主要由上述8個方法組成

  • onCreate表示Activity已經被創建(初始化)

在該方法中我們可以做一些初始化的相關操作

  1. 載入佈局資源文件:setContentView(R.layout.XX);
  2. 初始化數據:findViewById(R.id.XX);
  • onRestart 通常在Activity從不可見, 重新變為可見時, 在onStart之前調用
  • onStart 表示Activity已經顯示出來, 但是不能進行交互
  • onResume 表示Activity不僅僅顯示出來, 而且已經在前臺活動
  • onPause 表示Activity退出前臺活動

在該方法中可以做以下操作:
1: 儲存數據
2: 停止動畫
onStop:表示Acitivity正在停止或者即將被銷毀
onDestroy:表示Activity的銷毀, 所做的操作和onCreate正好相反
PS: 耗時操作不要放到onPause或onStop中

  1. 首次打開:onCreate()->onStart()->onResume()
  2. 按back鍵結速應用程式:onPause()->onStop()->onDestory()
  3. 按home鍵隱藏應用程式:onPause()->onStop()//此時程式未銷毀
  4. 再次啟動應用程式:onRestart()->onStart()->onResume()
  5. 從Activity(A)跳轉到Activity(B):onPause(A)->onCreate(B)->onStart(B)->onResume(B)->onStop(A)

 (2)異常情況下的生命周期

 當用戶轉動屏幕時,Activity銷毀並重建的過程如下:

onPause()->onSaveInstanceState()->onStop()->onDestory()->onCreate()->onStart()->onRestoreInstanceState()->onResume()

系統自帶的控制項, 如TextView的文本內容Android系統會幫我們保存和恢復
App的狀態, 則需要我們自己在onSaveInstanceState和onRestoreInstanceState中保存和恢復

@Override
protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    Log.i(TAG, "onSaveInstanceState");
    
    outState.putString(BUNDLE_DATA, "xyz");
}
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
    super.onRestoreInstanceState(savedInstanceState);
    Log.i(TAG, "onRestoreInstanceState: " + savedInstanceState.getString(BUNDLE_DATA));
}
View Code

我們能否在系統配置更新時, 自己對Activity的生命周期進行控制呢?
答案是可以的, android提供了這樣的機制
我們在AndroidManifest.xml中的Activity描述中添加如下配置
android:configChanges="orientation|screenSize"
再次旋轉屏幕看看, Activity並沒有銷毀和重建了

四、Activity啟動模式

與Activity生命周期息息相關的是Activity啟動模式,不同的啟動模式,導致的Activity生命周期則不同。

Activity有如下4種啟動模式:

  • standard
  • singleTop
  • singleTask
  • singleInstance

1: standard

Step 1: (standard launch)FirstActivity
Current Task Stack:
++++FirstActivity
Step 2: (standard launch)SecondActivity Current Task Stack: ++++SecondActivity ++++FirstActivity
Step 3: (standard launch)FirstActivity Current Task Stack: ++++FirstActivity ++++SecondActivity ++++FirstActivity

standard下: 總是會新建一個Activity入棧

Standard,預設的啟動模式,只要激活了Activity,就會創建一個新的實例,並放入任務棧中,這樣任務棧中可能同時存在一個Activity的多個實例。

2: singleTop

Step 1: (standard launch)FirstActivity
Current Task Stack:
++++FirstActivity
Step 2: (standard launch)SecondActivity Current Task Stack: ++++SecondActivity ++++FirstActivity
Step 3: (singleTop launch)SecondActivity Current Task Stack: ++++SecondActivity ++++FirstActivity

singleTop下: 如果棧頂是該Activity, 則不新建, 如果棧頂不是該Activity, 則新建該Activity

SingleTop,激活Activity時,如果棧頂是Activity,就不會創建新的實例,如果棧頂不是這個Activity,則會創建新的實例對象。

3: singleTask

Step 1: (standard launch)FirstActivity
Current Task Stack:
++++FirstActivity
Step 2: (standard launch)SecondActivity Current Task Stack: ++++SecondActivity ++++FirstActivity
Step 3: (singleTask launch)FirstActivity Current Task Stack: ++++FirstActivity

singleTask下: 如果棧里已經存在該Activity, 即pop到該Activity, 如果棧里沒有該Activity, 則新建Activity

singleTask,如果棧中存在Activity的實例,則將棧中該實例以上的其他Activity的實例移除,讓該Activity的實例處於棧頂,如果棧中不存在該實例,則創建新的實例。

4: singleInstance

Step 1: (standard launch)FirstActivity
Current Task Stack:
++++FirstActivity
Step 2: (singleInstance launch)ThirdActivity Current Task Stack: ++++FirstActivity ++++ThirdActivity
Step 3: (standard launch)SecondActivity Current Task Stack: ++++SecondActivity ++++FirstActivity ++++ThirdActivity

singleInstance下: 會新開一個棧, 單獨放置該Activity

多個應用共用Activity的一個實例,不論是否是同一個應用,只要是激活該Activity,都重用這個實例。

五、Activity實例

1.Activity註冊

1 // in AndroidManifest.xml
2 <activity android:name=".SecondActivity" >
3 </activity>
View Code

2.Activity之Intent

 1 // in FirstActivity.java
 2 @Override
 3 protected void onCreate(Bundle savedInstanceState) {
 4     super.onCreate(savedInstanceState);
 5     setContentView(R.layout.activity_first);
 6     Button standardButton = (Button) findViewById(R.id.standard_button);
 7     standardButton.setOnClickListener(new OnClickListener() {
 8         @Override
 9         public void onClick(View arg0) {
10             Intent intent = new Intent(FirstActivity.this,
11                     SecondActivity.class);
12             startActivity(intent);
13         }
14     });
15 }
View Code

3.Activity之Intent-Filter

1 //in mainifest.xml
2 <intent-filter>
3     <action android-name="android.intent.action.MAIN" />
4     <category android-name="android.intent.category.LAUNCHER" />
5 </intent-filter>
View Code

4.Activity間通信: FirstActivity -> SecondActivity

 1 // in FirstActivity.java
 2 public static final String EXTRA_DATA = "extra_data";
 3 @Override
 4 protected void onCreate(Bundle savedInstanceState) {
 5     super.onCreate(savedInstanceState);
 6     setContentView(R.layout.activity_first);
 7     Button standardButton = (Button) findViewById(R.id.standard_button);
 8     standardButton.setOnClickListener(new OnClickListener() {
 9         @Override
10         public void onClick(View arg0) {
11             Intent intent = new Intent(FirstActivity.this,
12                     SecondActivity.class);
13             intent.putExtra(EXTRA_DATA, "cba");
14             startActivityForResult(intent, REQUEST_CODE);
15         }
16     });
17 }
18 // in SecondActivity.java
19 @Override
20 protected void onCreate(Bundle savedInstanceState) {
21     super.onCreate(savedInstanceState);
22     setContentView(R.layout.activity_second);
23     Intent intent = getIntent();
24     Toast.makeText(
25             SecondActivity.this,
26             "Data from FirstActivity: "
27                     + intent.getStringExtra(FirstActivity.EXTRA_DATA),
28             Toast.LENGTH_LONG).show();
29 }
View Code

5.Activity間通信: SecondActivity -> FirstActivity

 1 // in FirstActivity.java
 2 protected void onCreate(Bundle savedInstanceState) {
 3     super.onCreate(savedInstanceState);
 4     setContentView(R.layout.activity_first);
 5     Button standardButton = (Button) findViewById(R.id.standard_button);
 6     standardButton.setOnClickListener(new OnClickListener() {
 7         @Override
 8         public void onClick(View arg0) {
 9             Intent intent = new Intent(FirstActivity.this,
10                     SecondActivity.class);
11             startActivityForResult(intent, REQUEST_CODE);
12         }
13     });
14 }
15 // in SecondActivity.java
16 @Override
17 protected void onResume() {
18     super.onResume();
19     Intent intent = new Intent();
20     intent.putExtra(EXTRA_DATA, "abc");
21     setResult(Activity.RESULT_OK, intent);
22 }
23 // in FirstActivity.java
24 @Override
25 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
26     if (resultCode != Activity.RESULT_OK) {
27         return;
28     }
29     switch (requestCode) {
30     case REQUEST_CODE:
31         Toast.makeText(
32                 FirstActivity.this,
33                 "Result from SecondActivity: "
34                         + data.getStringExtra(SecondActivity.EXTRA_DATA),
35                 Toast.LENGTH_LONG).show();
36         break;
37     default:
38         break;
39     }
40 }
View Code

6.配置Activity啟動模式
靜態方式
即在AndroidManifest.xml中配置

android:launchMode="singleTop"
android:launchMode="singleTask"
android:launchMode="singleInstance"

動態方式
即在源碼中配置

intent.addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JQuery可以創建顯示、隱藏、切換、滑動以及自定義動畫等效果。 1.hide()/show() hide()/show()是最基礎也是用的最多的一種效果,它用來控制元素的隱藏與顯示。 下麵是還沒有進行hide()/show()操作的示例: <style> .demo { margin:100px ...
  • 1、數組API——splice: ①刪除:var deletes=arr.splice(starti,n);刪除starti位置開始的n個,返回刪除元素組成的臨時數組; ②插入:arr.splice(starti,0,值1,值2……);在starti位置插入值1,值2……; ③替換:var dele ...
  • ...
  • 1.從SetContentView講起 1.1Activty的setContentView裡面的內容 首先這個getWindow是什麼? mWindow, 作用: 在attach@ativity 方法裡面定義的。預設就是PhoneWindow.也就是Activity裡面包含的window實例。 @O ...
  • 需要[tableView reloadData]後需要立即獲取tableview的cell、高度,或者需要滾動tableview,那麼,直接在reloadData後執行代碼是會有問題的。 斷點調試感覺[tableview reloaddata]是個非同步操作導致下麵的代碼並不會再它執行完後才執行。 於 ...
  • UIDatePickerDemo 效果 用法 1.導入文件(CustomDatePickerView.h/.m 和UIView+SetRect.h/.m) 2.在所要用到地方導入頭文件 #import "CustomDatePickerView.h" ,還有一個代理需要遵守 <CustomDateP ...
  • 屏蔽iOS10模擬器海量的垃圾debug信息 不屏蔽之前 進行如下設置 OS_ACTIVITY_MODE = disable 即可屏蔽垃圾信息 ...
  • Android Weekly Issue #222, 中文筆記. 本期文章包括: Okio中的三個方法, 檢測測試覆蓋率對build時間的影響, Android Support Annotations, Espresso測試相關, 一個新的MVP庫ThirtyInch的介紹, Android學習資... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...