Activity其实是继承了ApplicationContext这个类,我们可以重写以下方法,如下代码:
-
publicclassActivityextendsApplicationContext{
-
protectedvoidonCreate(BundlesavedInstanceState);
-
-
protectedvoidonStart();
-
-
protectedvoidonRestart();
-
-
protectedvoidonResume();
-
-
protectedvoidonPause();
-
-
protectedvoidonStop();
-
-
protectedvoidonDestroy();
-
}
-
packagecom.tutor.activitydemo;
-
importandroid.app.Activity;
-
importandroid.os.Bundle;
-
importandroid.util.Log;
-
publicclassActivityDemoextendsActivity{
-
-
privatestaticfinalStringTAG="ActivityDemo";
-
-
publicvoidonCreate(BundlesavedInstanceState){
-
super.onCreate(savedInstanceState);
-
setContentView(R.layout.main);
-
-
Log.e(TAG,"startonCreate~~~");
-
}
-
-
@Override
-
protectedvoidonStart(){
-
super.onStart();
-
Log.e(TAG,"startonStart~~~");
-
}
-
-
@Override
-
protectedvoidonRestart(){
-
super.onRestart();
-
Log.e(TAG,"startonRestart~~~");
-
}
-
-
@Override
-
protectedvoidonResume(){
-
super.onResume();
-
Log.e(TAG,"startonResume~~~");
-
}
-
-
@Override
-
protectedvoidonPause(){
-
super.onPause();
-
Log.e(TAG,"startonPause~~~");
-
}
-
-
@Override
-
protectedvoidonStop(){
-
super.onStop();
-
Log.e(TAG,"startonStop~~~");
-
}
-
-
@Override
-
protectedvoidonDestroy(){
-
super.onDestroy();
-
Log.e(TAG,"startonDestroy~~~");
-
}
-
-
}
第三步:运行上述工程,效果图如下:
核心在Logcat视窗里,如果你还不会用Logcat你可以看一下我的这篇文章Log图文详解(Log.v,Log.d,Log.i,Log.w,Log.e),我们打开应用时先后执行了onCreate()->onStart()->onResume三个方法,看一下LogCat视窗如下:
BACK键:
当我们按BACK键时,我们这个应用程序将结束,这时候我们将先后调用onPause()->onStop()->onDestory()三个方法,如下图所示:
HOME键:
当我们打开应用程序时,比如浏览器,我正在浏览NBA新闻,看到一半时,我突然想听歌,这时候我们会选择按HOME键,然后去打开音乐应用程序,而当我们按HOME的时候,Activity先后执行了onPause()->onStop()这两个方法,这时候应用程序并没有销毁。如下图所示:
而当我们再次启动ActivityDemo应用程序时,则先后分别执行了onRestart()->onStart()->onResume()三个方法,如下图所示:
这里我们会引出一个问题,当我们按HOME键,然后再进入ActivityDemo应用时,我们的应用的状态应该是和按HOME键之前的状态是一样的,同样为了方便理解,在这里我将ActivityDemo的代码作一些修改,就是增加一个EditText。
第四步:修改main.xml布局文件(增加了一个EditText),代码如下:
-
<?xmlversion="1.0"encoding="utf-8"?>
-
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
-
android:orientation="vertical"
-
android:layout_width="fill_parent"
-
android:layout_height="fill_parent"
-
>
-
<TextView
-
android:layout_width="fill_parent"
-
android:layout_height="wrap_content"
-
android:text="@string/hello"
-
/>
-
<EditText
-
android:id="@+id/editText"
-
android:layout_width="fill_parent"
-
android:layout_height="wrap_content"
-
/>
-
</LinearLayout>
第五步:然后其他不变,运行ActivityDemo程序,在EditText里输入如"Frankie"字符串(如下图:)
这时候,大家可以按一下HOME键,然后再次启动ActivityDemo应用程序,这时候EditText里并没有我们输入的"Frankie"字样,如下图:
这显然不能称得一个合格的应用程序,所以我们需要在Activity几个方法里自己实现,如下第六步所示:
第六步修改ActivityDemo.java代码如下:
-
packagecom.tutor.activitydemo;
-
importandroid.app.Activity;
-
importandroid.os.Bundle;
-
importandroid.util.Log;
-
importandroid.widget.EditText;
-
publicclassActivityDemoextendsActivity{
-
-
privatestaticfinalStringTAG="ActivityDemo";
-
privateEditTextmEditText;
-
-
privateStringmString;
-
publicvoidonCreate(BundlesavedInstanceState){
-
super.onCreate(savedInstanceState);
-
setContentView(R.layout.main);
-
mEditText=(EditText)findViewById(R.id.editText);
-
Log.e(TAG,"startonCreate~~~");
-
}
-
-
@Override
-
protectedvoidonStart(){
-
super.onStart();
-
Log.e(TAG,"startonStart~~~");
-
}
-
-
@Override
-
protectedvoidonRestart(){
-
super.onRestart();
-
mEditText.setText(mString);
-
Log.e(TAG,"startonRestart~~~");
-
}
-
-
@Override
-
protectedvoidonResume(){
-
super.onResume();
-
Log.e(TAG,"startonResume~~~");
-
}
-
-
-
@Override
-
protectedvoidonPause(){
-
super.onPause();
-
mString=mEditText.getText().toString();
-
Log.e(TAG,"startonPause~~~");
-
}
-
-
@Override
-
protectedvoidonStop(){
-
super.onStop();
-
Log.e(TAG,"startonStop~~~");
-
}
-
-
@Override
-
protectedvoidonDestroy(){
-
super.onDestroy();
-
Log.e(TAG,"startonDestroy~~~");
-
}
-
-
}
第七步:重新运行ActivityDemo程序,重复第五步操作,当我们按HOME键时,再次启动应用程序时,EditText里有上次输入的"Frankie"字样,如下图如示:
理解Activity的生命周期对于我们去开发大的灵活的应用很有帮助,在Android系统中Activity作为Activity栈来被管理,当前活动的Activity处于栈顶,之前的不活动的Activity就会被压入下面的称为不活动的Activity,来进行等待,如果该Activity重新变成栈顶,就会被重新恢复活动的状态;
看下自己画的截图:
1: Activity A正在运运行,然后又打开Activity B之后 Activity A就会退到栈的下一层,Activity B在栈顶.
2:如果用户点击后退按钮进行返回,或者前台的Activity结束这里(可以认为是正在运行的Activity B),此时该Activity就会被移除栈,直接被销毁;然后站内的上一个Activity(这里认为是Activity A)将会到栈顶,并且变成活动状态: 如图:
下面是代码日志截图:
3:接下来看下Activity生命周期中的四个重要状态
活动状态 -----> 在屏幕的最前面(也就是在栈顶),获得焦点并且可见
暂停状态 -----> 失去焦点,不过还是可见 例如:屏幕上面弹出来的Dialog
停止状态 -----> 失去焦点,不可见
销毁状态 -----> 被系统销毁
1:完整生命周期:Activity的完整生命周期自第一次调用onCreate()开始,直至调用onDestroy()为止。Activity在onCreate()中设置并且进行初始化,而在onDestroy()中释放所有系统资源。
2:可见生命周期:Activity的可视生命周期自onStart()调用开始直到相应的onStop()调用结束。在此期间,用户可以在屏幕上看到Activity,尽管它也许并不是位于前台或者也不与用户进行交互。在这两个方法之间,我们可以保留用来向用户显示这个Activity所需的资源。
3:前台可见生命周期:Activity的前台生命周期自onResume()调用起,至相应的onPause()调用为止。在此期间,Activity位于前台最上面并与用户进行交互。Activity会经常在暂停和恢复之间进行状态转换
①:一个Activity的启动顺序:onCreate()--->onStart()--->onResume()
②:当先打开一个Activity的时候 第一个Activity先会调用onPause() ----然后第二个Activity调用onCreate()--->onStart()--->onResume()---->第一个Activity调用onStop();
③:返回到第一个Activity的时候 第二个Activity会先调用onPause()---->然后第一个Activity调用onRestart()--->onStart()--->onResume()---->第二个Activity接着调用onStop()——>onDestory();
④:当activity1上面弹出对话框activity2时,依次执行activity1的onPause()---->activity2的一系列,
⑤:此时关闭屏幕,先activity2的onPause()--->onStop(),再activity1的onStop()
⑥:此时点亮屏幕,先上层的对话框activity2的onRestart()-->onStart(),再下层的activity1的onRestart()-->onStart();最后上层对话框activity2的onResume()。
⑦:对话框activity2消失,
依次执行activity2的onPause()---->activity1的onResume()--->activity2的onStop()onDestroy()
⑧:当在activity1上关闭屏幕时,依次onPause()--->onStop()
下面来说说Activity的onSaveInstanceState()和 onRestoreInstanceState()方法
如果我们需要在Activity销毁前保存一些临时性的数据,onPause()就比较可以进行数据的持久化的保存,此时我们可以使用onSaveInstanceState()和 onRestoreInstanceState()方法。只要重写上面两个方法,在这里进行数据保存操作就OK了
分享到:
相关推荐
总之,深入理解Activity生命周期和其背后的源码逻辑,对于编写高效、响应迅速且用户体验优秀的Android应用至关重要。开发者应熟练掌握这些知识点,以便在设计和调试应用时能得心应手。通过实践和分析ActivityDemo,...
Android Studio提供了多种工具帮助开发者调试Activity生命周期。例如: 1. **Android Profiler**:可以实时监控Activity的生命周期状态变化,同时分析内存、CPU和网络使用情况。 2. **Logcat**:通过打印日志,可以...
这是Activity生命周期中的活动状态。 4. **onPause()**:当Activity被部分或完全覆盖,但仍可见(例如弹出一个透明对话框)时调用。在此阶段,应保存临时数据,但不应进行耗时操作,因为这会影响用户体验。 5. **...
### Android Activity 生命周期详解 #### 一、Activity的生命周期概述 在Android开发中,`Activity`是构成应用的基本单元之一,负责处理用户交互并显示界面。每个`Activity`都有其特定的生命周期,即从创建到销毁...
在Android开发中,Activity是...理解并熟练掌握Activity生命周期对于开发高效、响应式的Android应用至关重要。通过正确处理生命周期事件,开发者可以确保应用在各种场景下都能提供良好的用户体验,并有效地管理资源。
本文将详细解析从一个Activity(Activity1)跳转到另一个Activity(Activity2),然后再返回到原Activity(Activity1)时,这两个Activity分别会经历哪些生命周期方法。 #### Activity1的生命周期变化 1. **...
### Android Activity 生命周期详解 #### 一、概述 在Android开发中,`Activity`是四大组件之一,用于构建用户界面,并负责与用户的交互。一个`Activity`通常对应着一个屏幕,当用户在一个应用的不同屏幕间导航时...
#### Activity生命周期详解 下面是一些Activity生命周期中关键的回调方法及其作用: - **onCreate**: Activity首次被创建时调用,通常用于初始化UI和数据。 - **onStart**: Activity变为用户可见时调用。 - **...
在ExmActLife这个文件中,很可能包含了不同生命周期方法的示例代码,以及模拟不同启动模式的实验,通过这些实践,开发者可以更好地理解和掌握Activity生命周期的控制,从而优化应用性能和用户体验。实践中,我们应...
在Android开发中,理解Activity的生命周期对于管理应用的状态和资源至关重要。Activity是构成Android应用程序的主要构建块之一,它负责提供用户界面并处理与用户交互相关的事件。Activity的生命周期由一系列回调方法...
### Activity生命周期详解 #### 概述 Android应用开发中,`Activity`是四大基础组件之一,主要用于构建用户界面。理解`Activity`的生命周期对于管理应用的状态、资源以及响应用户交互至关重要。 #### `Activity`...
在"Activity生命周期完美呈现"的项目中,开发者可以创建一个简单的Activity,通过Log输出或可视化的方式,展示Activity在不同状态间的转换,这样可以直观地看到每个生命周期方法的调用顺序,加深理解。 总之,理解...
### Android的Activity生命周期详解 #### 一、Activity生命周期概述 在Android开发中,理解Activity的生命周期至关重要。Activity是Android四大组件之一,它负责为用户提供一个可视化的交互界面。每个Activity都有...
Android中的Activity生命周期是每个Android开发者必须深入理解和掌握的关键概念。Activity是Android应用程序的基本构建块,它代表用户界面的一个屏幕。了解其生命周期对于优化应用性能、处理资源管理以及确保正确...
android中Activity生命周期过程的详细解析
### Activity的生命周期...通过上述分析,我们可以清楚地了解Activity的生命周期以及Android系统是如何管理和优化内存资源的。这对于开发者来说是非常重要的知识点,有助于编写高效、稳定的Android应用程序。
Activity 的生命周期。 一、理解Activity Activity是Android程序的4大组件之一。 Activity是Android程序的表示层。程序的每一个显示屏幕就是一个Activity。 学过WEB开发的同学,可以把Activity理解成网页中的一个...
Android中的Activity生命周期是每个Android开发者必须深入理解的关键概念。它涉及到Activity从创建到销毁的整个过程,以及在不同用户交互和系统状态变化时如何响应。本文将详细解析Activity的生命周期,并通过实例...
Android Activity生命周期和堆栈管理的详解 Android Activity生命周期是指Activity从创建到销毁的整个过程,包括了七个回调方法:onCreate、onStart、onRestart、onResume、onPause、onStop、onDestroy。这些方法...
了解Activity的生命周期对于创建健壮、高效的应用至关重要。Activity具有三个主要状态:运行(Running)、暂停(Paused)和停止(Stopped),以及一些过渡状态。 1. **运行状态(Running)**: 当Activity位于任务...