2-AI–Activity啟動方式
零、前言
standard:預設的啟動模式
|---啟動一個Activity,該Activity就會在返回棧中入棧
|---該Activity處於棧頂的位置
|---每次啟動都會建立該Activity的新例項
singleTop:
|---在啟動活動時若棧頂已經是該Activity,則認為可以直接使用它
singleTask:
|---整個應用程式的上下文中只存在一個例項
|---兩次相同例項之間的Activity會被殺死
singleInstance:
|---啟用一個新的返回棧來管理這個活動
一、測試類
Activity1
public class Activity1 extends AppCompatActivity {
@BindView(R.id.btn_start_self)
Button mBtnStartSelf;
@BindView(R.id.button_start_others)
Button mButtonStartOthers;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.ac_task);
ButterKnife.bind(this);
Log.e("TASK_ID", "Activity1 Task id is " + getTaskId());
}
@OnClick({R.id.btn_start_self, R.id.button_start_others})
public void onViewClicked(View view) {
switch (view.getId()) {
case R.id.btn_start_self:
startActivity(new Intent(Activity1.this, Activity1.class));
break;
case R.id.button_start_others:
startActivity(new Intent(Activity1.this, Activity2.class));
break;
}
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.e("TASK_ID", "Activity1 銷燬");
}
}
Activity2
public class Activity2 extends AppCompatActivity {
@BindView(R.id.btn_start_self)
Button mBtnStartSelf;
@BindView(R.id.button_start_others)
Button mButtonStartOthers;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.ac_task);
ButterKnife.bind(this);
Log.e("TASK_ID", "Activity2 Task id is " + getTaskId());
}
@OnClick({R.id.btn_start_self, R.id.button_start_others})
public void onViewClicked(View view) {
switch (view.getId()) {
case R.id.btn_start_self:
startActivity(new Intent(Activity2.this, Activity2.class));
break;
case R.id.button_start_others:
startActivity(new Intent(Activity2.this, Activity1.class));
break;
}
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.e("TASK_ID", "Activity2 銷燬");
}
}
佈局:ac_task.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/btn_start_self"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:text="開啟自己"
android:textAllCaps="false"
app:layout_constraintTop_toTopOf="parent"
tools:layout_editor_absoluteX="30dp"/>
<Button
android:id="@+id/button_start_others"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="16dp"
android:text="開啟別人"
app:layout_constraintStart_toEndOf="@+id/btn_start_self"
app:layout_constraintTop_toTopOf="parent"/>
</android.support.constraint.ConstraintLayout>
三、測試結果分析:
1:standard模式:Activity1、2皆為standard
依次開啟Activity1、2、2、1、2
E/TASK_ID: Activity1 Task id is 89
E/TASK_ID: Activity2 Task id is 89
E/TASK_ID: Activity2 Task id is 89
E/TASK_ID: Activity1 Task id is 89
E/TASK_ID: Activity2 Task id is 89
依次返回
E/TASK_ID: Activity2 銷燬
E/TASK_ID: Activity1 銷燬
E/TASK_ID: Activity2 銷燬
E/TASK_ID: Activity2 銷燬
E/TASK_ID: Activity1 銷燬
:2:singleTop模式:Activity1為standard, Activity2 為singleTop
依次開啟Activity1、2、2、1、2
E/TASK_ID: Activity1 Task id is 82
E/TASK_ID: Activity2 Task id is 82
E/TASK_ID: Activity1 Task id is 82
E/TASK_ID: Activity1 Task id is 82
依次返回
E/TASK_ID: Activity1 銷燬
E/TASK_ID: Activity1 銷燬
E/TASK_ID: Activity2 銷燬
E/TASK_ID: Activity1 銷燬
可見第二次開啟Activity2時並無變化,因為singleTop模式,第二次的Activity2並沒有建立
:3:singleTask模式:Activity1為standard, Activity2 為singleTask
依次開啟Activity1、2、2、1、2
E/TASK_ID: Activity1 Task id is 94
E/TASK_ID: Activity2 Task id is 94
E/TASK_ID: Activity1 Task id is 94
E/TASK_ID: Activity1 銷燬
依次返回
E/TASK_ID: Activity2 銷燬
E/TASK_ID: Activity1 銷燬
可見第二次開啟Activity2時並無變化,第三次開啟Activity2,Activity1銷燬
:4:singleInstance模式:Activity1為standard, Activity2 singleInstance
依次開啟Activity1、2、2、1、2
E/TASK_ID: Activity1 Task id is 115
E/TASK_ID: Activity2 Task id is 116
E/TASK_ID: Activity1 Task id is 115
依次返回
E/TASK_ID: Activity2 銷燬
E/TASK_ID: Activity1 銷燬
E/TASK_ID: Activity1 銷燬
可見Activity2單獨在一個棧中,多次開啟Activity2不會新建例項
後記、
1.宣告:
[1]本文由張風捷特烈原創,轉載請註明
[2]歡迎廣大程式設計愛好者共同交流
[3]個人能力有限,如有不正之處歡迎大家批評指證,必定虛心改正
[4]你的喜歡與支援將是我最大的動力
2.連線傳送門:
更多安卓技術歡迎訪問:安卓技術棧
我的github地址:歡迎star
簡書首發,騰訊雲+社群同步更新
張風捷特烈個人網站,程式設計筆記請訪問:http://www.toly1994.com
3.聯絡我
QQ:1981462002
郵箱:1981462002@qq.com
微信:zdl1994328
4.歡迎關注我的微信公眾號,最新精彩文章,及時送達:
相關文章
- Android中Activity的四種啟動方式Android
- Activity啟動模式模式
- Activity啟動流程分析
- Activity啟動模式(GIF 動態演示)模式
- Android-Activity的啟動模式Android模式
- Activity啟動流程原始碼分析原始碼
- Android Activity啟動流程原始碼分析Android原始碼
- Activity生命週期與啟動模式模式
- Android程式啟動與Activity顯示Android
- 庖丁解牛 Activity 啟動流程
- 從Activity的啟動流程理解Binder
- 根Activity元件的啟動過程元件
- Android原始碼分析:Activity啟動流程Android原始碼
- Activity 的 "啟動流程"(基於 Android 9.0)Android
- Android 8.0 原始碼分析 (四) Activity 啟動Android原始碼
- 原始碼閱讀之Activity啟動與App啟動流程 – Android 9.0原始碼APPAndroid
- 原始碼閱讀之Activity啟動與App啟動流程 - Android 9.0原始碼APPAndroid
- Android Activity是如何啟動的?Activity的生命週期是如何呼叫的?Android
- java啟動方式Java
- ActivityRecord、TaskRecord、ActivityStack以及Activity啟動模式詳解模式
- Activity的啟動過程第二篇
- 組內技術分享-Activity 的啟動模式模式
- 一篇文章搞懂 Activity 啟動模式模式
- 一張圖弄清Activity的啟動過程
- Android學習筆記-Activity的啟動模式Android筆記模式
- hook 系統api啟動未註冊ActivityHookAPI
- 擼擼Android的羊毛(一)----Activity啟動模式Android模式
- App 啟動過程(含 Activity 啟動過程) | 安卓 offer 收割基APP安卓
- app啟動流程,activity啟動流程時序圖,binder相關資料APP時序圖
- [Android]關閉所有Activity,開啟某個ActivityAndroid
- Android系統原始碼分析--Activity啟動過程Android原始碼
- 深入理解Android 之 Activity啟動流程(Android 10)Android
- 深入理解Activity啟動流程和AMS框架(一)框架
- 深入理解Activity啟動流程和AMS框架(二)框架
- 深入理解Activity啟動流程和AMS框架(三)框架
- Android黑科技:如何啟動未註冊的ActivityAndroid
- Android入門教程之Activity(生命週期,啟動...)Android
- jar包啟動方式JAR