欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

16.Android-activity生命周期与启动模式

程序员文章站 2022-12-09 10:31:29
1.activity共有4个状态 如下图所示: 运行状态 如果一个活动位于屏幕的前台(可见的),那么它就是活动的或正在运行的。 暂停状态 如果一个活动失去了焦点,但仍然可见(也就是说,一个新的非全尺寸或透明的活动将焦点放在了活动的顶部),那么它将被暂停。暂停的活动是完全活动的(它维护所有状态和成员信 ......

1.activity共有4个状态

如下图所示:

16.Android-activity生命周期与启动模式

运行状态

如果一个活动位于屏幕的前台(可见的),那么它就是活动的或正在运行的。

暂停状态

如果一个活动失去了焦点,但仍然可见(也就是说,一个新的非全尺寸或透明的活动将焦点放在了活动的顶部),那么它将被暂停。暂停的活动是完全活动的(它维护所有状态和成员信息,并保持与窗口管理器的连接),但是在内存极低的情况下,系统可能会终止它。

比如:当前app出现一个非全尺寸的对话框

停止状态

如果一个活动完全被另一个活动遮挡住了,它就会被停止。它仍然保留所有的状态和成员信息,但是,它对用户来说不再可见,所以它的窗口是隐藏的,当在其他地方需要内存时,会被系统杀死。

比如:app在后台运行

销毁状态

activity被系统杀死或者调用finish方法主动退出

 

可以重写的方法有:

  • onstart() : 当oncreate()之后,会调用该方法
  • onresume() : 当onstart ()之后或者取消暂停后,会调用该方法
  • onrestart() : 当取消停止后,会调用该方法
  • onpause() : 当另个非全尺寸或透明的活动将焦点放在了活动的顶部,那么该活动就会进入暂停状态,然后调用该方法
  • onstop() : 当前活动被另个活动完全覆盖后(比如有人打电话过来),那么该活动就会进入停止状态,然后调用该方法,一般在这个方法中停止所有关于刷新界面的操作.
  • ondestroy() : activity被系统杀死或者调用finish方法主动退出,那么会调用该方法, 一般在这个方法中用于释放资源,

 

2.activity启动模式

在android开发中,如果我们通过一个按钮重复打开5个相同的activity的话, 系统就会创建多个实例并把它们放入任务栈中,然后我们点击返回键时,当前正在显示的activity(栈顶的实例)则会出栈,然后显示之前入栈的实例,要退出的话,必须也要点击5个相同的返回键. 这样其实非常耗资源,并且每个相同的activity都是独立的实例(数据分开的),会给用户带来困扰,为了了解决这一问题,android为actiivty提供了启动模式launchmode

启动模式launchmode

activity的启动模式有四种:standard(系统默认的模式)、singletop、singletask和singleinstance,如下图所示:

 16.Android-activity生命周期与启动模式

 

2.1 standard标准模式

系统默认的模式,配置该模式的activity不管在任务栈中是否已存在,都会创建出来.

比如:我们通过一个按钮重复打开5个相同的activity的话,那么退出的话,必须也要点击5个相同的返回键.因为每个相同的activity都是独立的.

manifest中配置如下:

android:launchmode=”standard”   //可以不写,因为默认就是standard模式。

 

2.2 singletop栈顶单独模式

在栈顶只能拥有唯一的实例,使用该模式的话,如果当前要启动的activity是栈顶的activity,那么就不会被创建,并且不发生任何变化.

比如:我们在当前mainactivity中通过按钮重复打开第二个mainactivity,系统就会检测到当前栈顶正在运行的activity实例等于要打开的activity实例,就不会创建实例.

如果我们打开的顺序是mainactivity->secondactivity->mainactivity(栈顶,当前正在显示的界面),则这3个实例会正常的创建出来.

manifest中配置如下:

android:launchmode=" singletop" 

用于该模式的常见activity比如有: 二维码扫码界面activity(避免打开多个相同界面)

 

2.3 singletask单独实例模式

在栈中只能拥有唯一实例,创建使用该模式的activity的实例之前,会自动在任务栈中匹配实例,如果之前未创建,那么就在栈顶创建一个实例,如果已存在,那么会将它上面的其它所有activity全部出栈, 然后显示当前已经创建的activity,并且会回调该实例的onnewintent()方法。

比如:

我们设置mainactivitysingletask模式

secondactivitystandard默认模式

然后打开的顺序是mainactivity->secondactivity->secondactivity->secondactivity(栈顶,当前正在显示的界面)。

接下来我们再次打开mainactivity,由于mainactivity为singletask,那么系统就会将它上面的其它所有activity全部出栈,所以就变成了: mainactivity(栈顶,当前正在显示的界面),这时点击返回键的话,那么就直接退出到桌面了.

 

manifest中配置如下:

android:launchmode="singletask"

用于该模式的常见activity比如有:主界面activity

 

2.4 singleinstance单例模式

该模式比较特殊,创建使用该模式的activity的实例会自动占用一个独立任务栈, 具有全局唯一性,如果我们要创建的activity已存在,那么就会显示当前已经创建的activity.

比如:

我们设置mainactivity为standard默认模式secondactivity为singleinstance模式

然后打开的顺序是mainactivity->secondactivity (栈顶,当前正在显示的界面)。

接下来我们再次打开mainactivity,由于mainactivity和secondactivity是分开的任务栈,所以这次激活的是mainactivity所在的任务栈,那么secondactivity独立任务栈就会被压在最下面,所以就变成了:

secondactivity-> mainactivity (最开始的界面)-> mainactivity (栈顶,当前正在显示的界面).

 

manifest中配置如下:

android:launchmode="singleinstance"

 

用于该模式的常见activity比如有:浏览器界面activity(任何界面都可以去调用它访问网页)