Android基础学习【历史流程重走】 ---- Activity的生命周期

2024-08-31 20:32

本文主要是介绍Android基础学习【历史流程重走】 ---- Activity的生命周期,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、Activity生命周期概述

1,Activity生命周期组成

public class Activity extends ApplicationContext {  protected void onCreate(Bundle savedInstanceState);  protected void onStart();     protected void onRestart();  protected void onResume();  protected void onPause();   protected void onStop();  protected void onDestroy();  }  

           entire lifetime (整个生命周期)

一个Activity整个生命周期,存在于onCreate()方法和onDestroy()调用之间。Activity应该在onCreate()方法里设置“全局”状态(如定义布局)。在onDestroy()方法里释放所有资源。

            visible lifetime(可见生命周期)

一个Activity可见生命周期,存在于onStart()和onStop()调用之间。用户可以看到屏幕上的activity并与之交互。在整个生命周期的活动中,系统可能会调用onStart()和onStop()多次,因为活动之间交替进行隐藏或显示给用户。

           foreground lifetime(前台生命周期)

一个Activity前台生命周期,存在于onResume()和onPause()调用之间。在这段时间里,这个Activity在其他所有Activity的前面,拥有用户输入焦点。Activity前台状态常发生转换,在这两个方法之间的代码应该是轻量级的,防止导致其他转换变慢使得用户需要等待。


2,经典Activity生命周期图

                                        


3,解析Activity生命周期

【1】启动Activity:系统会先调用onCreate方法,然后调用onStart方法,最后调用onResume,Activity进入运行状态。

【2】当前Activity被其他Activity覆盖其上或被锁屏:系统会调用onPause方法,暂停当前Activity的执行。

【3】当前Activity由被覆盖状态回到前台或解锁屏:系统会调用onResume方法,再次进入运行状态。

【4】当前Activity转到新的Activity界面或按Home键回到主屏,自身退居后台:系统会先调用onPause方法,然后调用onStop方法,进入停滞状态。

【5】用户后退回到此Activity:系统会先调用onRestart方法,然后调用onStart方法,最后调用onResume方法,再次进入运行状态。

【6】当前Activity处于被覆盖状态或者后台不可见状态,即第2步和第4步,系统内存不足,杀死当前Activity,而后用户退回当前Activity:再次调用onCreate方法、onStart方法、onResume方法,进入运行状态。

【7】用户退出当前Activity:系统先调用onPause方法,然后调用onStop方法,最后调用onDestory方法,结束当前Activity。

所以,常用以下对称图来理解Activity生命周期:
                                                

二、Activity生命周期详解

        1,重写生命周期方法,代码检测

/*** 验证Activity生命周期* <p/>* 作者:vision* 时间:2016/8/25*/
public class LifeCycleActivity extends Activity {private static final String TAG = "LifeCycleActivity";private Context context = this;private int temp = 1;/*** Activity创建时被调用*/@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);Log.i(TAG, "onCreate called.");setContentView(R.layout.activity_life_cycle);Button btn = (Button) findViewById(R.id.btn);btn.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(context, OrientationChangeActivity.class);startActivity(intent);}});}/*** Activity创建或者从后台重新回到前台时被调用*/@Overrideprotected void onStart() {super.onStart();Log.i(TAG, "onStart called.");}/*** Activity从后台重新回到前台时被调用*/@Overrideprotected void onRestart() {super.onRestart();Log.i(TAG, "onRestart called.");}/*** Activity创建或者从被覆盖、后台重新回到前台时被调用*/@Overrideprotected void onResume() {super.onResume();Log.i(TAG, "onResume called.");}/***  Activity窗口获得或失去焦点时被调用,在onResume之后或onPause之后*//*@Overridepublic void onWindowFocusChanged(boolean hasFocus) {super.onWindowFocusChanged(hasFocus);Log.i(TAG, "onWindowFocusChanged called.");}*//*** Activity被覆盖到下面或者锁屏时被调用*/@Overrideprotected void onPause() {super.onPause();Log.i(TAG, "onPause called.");//有可能在执行完onPause或onStop后,系统资源紧张将Activity杀死,所以有必要在此保存持久数据}/*** 退出当前Activity或者跳转到新Activity时被调用*/@Overrideprotected void onStop() {super.onStop();Log.i(TAG, "onStop called.");}/*** 退出当前Activity时被调用,调用之后Activity就结束了*/@Overrideprotected void onDestroy() {super.onDestroy();Log.i(TAG, "onDestory called.");}/*** Activity被系统杀死时被调用.* 例如:屏幕方向改变时,Activity被销毁再重建;当前Activity处于后台,系统资源紧张将其杀死.* 另外,当跳转到其他Activity或者按Home键回到主屏时该方法也会被调用,系统是为了保存当前View组件的状态.* 在onPause之前被调用.*/@Overrideprotected void onSaveInstanceState(Bundle outState) {outState.putInt("temp", temp);Log.i(TAG, "onSaveInstanceState called. put param: " + temp);super.onSaveInstanceState(outState);}/*** Activity被系统杀死后再重建时被调用.* 例如:屏幕方向改变时,Activity被销毁再重建;当前Activity处于后台,系统资源紧张将其杀死,用户又启动该Activity.* 这两种情况下onRestoreInstanceState都会被调用,在onStart之后.*/@Overrideprotected void onRestoreInstanceState(Bundle savedInstanceState) {temp = savedInstanceState.getInt("temp");Log.i(TAG, "onRestoreInstanceState called. get param: " + temp);super.onRestoreInstanceState(savedInstanceState);}public void showDialog(View view) {AlertDialog.Builder builder = new AlertDialog.Builder(this);builder.setMessage("确认退出程序弹出框?").setCancelable(false).setPositiveButton("确定", new DialogInterface.OnClickListener() {public void onClick(DialogInterface dialog, int id) {LifeCycleActivity.this.finish();}}).setNegativeButton("取消", new DialogInterface.OnClickListener() {public void onClick(DialogInterface dialog, int id) {dialog.cancel();}});builder.show();}
}
         2,运行情形查看

【1】创建LifeCycleActivity【整个生命周期】


【2】返回键,Button添加finish()


【3】LifeCycleActivity跳转其他Activity


【4】其他Activity返回LifeCycleActivity


【5】LifeCycleActivity展示时锁屏


【6】LifeCycleActivity展示时锁屏解锁


【7】LifeCycleActivity展示时弹出对话框,并不影响生命周期


三、细节强化

1,横竖屏切换

先在手机设置--显示--自动旋转屏幕 去修改手机属性。


           横竖屏切换,实际是生命周期先关闭再重新启用。

先保存数据,然后调用数据。

2,配置Activity属性

       android:screenOrientation="portrait"

            重写onConfigurationChanged()方法:

    /*** 当指定了android:configChanges="orientation"后,方向改变时onConfigurationChanged被调用*/@Overridepublic void onConfigurationChanged(Configuration newConfig) {super.onConfigurationChanged(newConfig);Log.i(TAG, "onConfigurationChanged called.");switch (newConfig.orientation) {case Configuration.ORIENTATION_PORTRAIT:setContentView(R.layout.activity_orientation_portrait);break;case Configuration.ORIENTATION_LANDSCAPE:setContentView(R.layout.activity_oritation_landscape);break;}}
           Android系统本身是会调用重写方法的。但是国内机型复杂,加上很多手机对系统软件有维护、更改,测试机型锤子、IUNI中就没能监听到。

实例源码 #_#



耐性韧性血性:凡事要沉下心来认真仔细做到完美,要有永不放弃的决心,要有毫不畏惧的勇气

我只有一根烟了,而我还要撑一夜,我只有一点爱了,而我还要过一生。 

这篇关于Android基础学习【历史流程重走】 ---- Activity的生命周期的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1124920

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss