从下图中可以看出Activity的生命周期函数挺多的,其实他的生命周期和以往我们看到的其他组件的生命周期一样,都是从创建到销毁的过程,只不过之间多加了几个生命周期函数。
我们可以使用一个apk来验证两个activity相互切换的过程和退出activity的过程。通过在每个步骤函数中打印TRACE,可以发现创建、运行、到销毁的流程。
(1)从Activity01切到Activity02
步骤是:Activity01.onCreate-》Activity01.onStart-》Activity01.onResume-》Activity01.onPause-》Activity02.onCreate-》Activity02.onStart-》Activity02.onResume-》Activity01.onStop-》Activity01.onDestroy。从上可以看出,直到Activity02创建完毕后,Activity01才完全销毁。
(2)从Activity01退出
步骤是:Activity01.onCreate-》Activity01.onStart-》Activity01.onResume-》Activity01.onPause-》Activity01.onStop-》Activity01.onDestroy。
如果想完整的退出一个activity,光用finish是不够的。仅仅finish掉,用360一查,发现进程还是存在的;当调用finish()时,只是将活动推向后台,并没有立即释放内存,活动的资源并没有被清理;当调用System.exit(0)时,杀死了整个进程,这时候活动所占的资源也会被释放。所以正确的做法是在onDestroy中调用System.exit。
=============================================Activity开机自启动========================================
某些时候,我们需要在开机时启动一个activity,做法就是为这个activity的class配一个receiver就可以了。方法是:
(1)activity本身不需要做任何改动
(2)XML中添加开机启动权限
<span style="font-size:12px;"><uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"></uses-permission></span>
(3)XML中receiver
<span style="font-size:12px;"> <receiver android:name=".BootBroadcastReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver> </span>
(4)BootBroadcastReceiver文件内容:
<span style="font-size:12px;">package com.example.screenorientationtest;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
public class BootBroadcastReceiver extends BroadcastReceiver {
static final String ACTION = "android.intent.action.BOOT_COMPLETED";
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
if (intent.getAction().equals(ACTION)) {
Intent sayHelloIntent = new Intent(context, MainActivity.class);
sayHelloIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(sayHelloIntent);
}
}
}
</span>
===============================Activity的四种启动模式===============================================
Activity的启动模式总结:
1). standard:堆栈(task):与应用程序的其他已启动过的Activity在同一个堆栈。实例创建:每次启动都会创建新的实例
2). singleTop:堆栈(task):与应用程序的其他已启动过的Activity在同一个堆栈。实例创建:启动时,检查是否有该Activity的实例在当前的栈顶(启动过的记录)。若有,则不再创建新实例,若无,则重新创建新实例,置于栈顶。
3). singleTask:堆栈(task): 与应用程序的其他已启动过的Activity在同一个堆栈。实例创建:启动时,检查task中是否有该Activity的实例。若有,则将task中在该Activity实例之上的所有其他Activity实例统统出栈(pop),使其在栈顶。若无,则重新创建该Activity实例,置于栈顶。
4). singleInstance:堆栈(task):与另外其他三种模式不同,会新建一个task,将Acitvity放置于这个新的task中,并保证不再有其他Activity实例进入。实例创建:第一次创建时,会新建一个task,将其至于新的task中。若实例已存在,在启动时,无需再创建新实例,复用之前已创建的实例。
参考原文:http://www.iteye.com/topic/1092061
参考原文:http://blog.csdn.net/u0fly/article/details/5909477(后部分)
参考原文:http://ask.csdn.net/questions/942
参考原文:http://blog.csdn.net/kevinofneu/article/details/20307005
参考原文:http://blog.csdn.net/eiuly/article/details/22779069
参考原文:http://bbs.csdn.net/topics/350051074
参考原文:http://blog.csdn.net/yanzi1225627/article/details/8592883