Fragment(四)Fragment生命周期分析(转)

Fragment(四)Fragment生命周期分析

转载请注明:http://blog.csdn.net/liaoqianchuan00/article/details/24271607

 

例子一 从Layout中加载Fragment:

 

假设我们有一个Activity的Layout中有两个Fragment:

<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"

android:id="@+id/container"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.example.androidtest.MainActivity"

android:orientation="horizontal"

tools:ignore="MergeRootFrame" >

<fragmentandroid:name="com.example.androidtest.FragmentA"

android:id="@+id/fragmentA"

android:layout_weight="1"

android:layout_width="match_parent"

android:layout_height="match_parent" />

<fragment android:name="com.example.androidtest.FragmentB"

android:id="@+id/fragmentB"

android:layout_weight="1"

android:layout_width="match_parent"

android:layout_height="match_parent" />

</LinearLayout>

而我们的Fragment很简单:

public class MainActivity extends FragmentActivity {

@Override

protectedvoid onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

Log.d("==========","MainActivity onCreate");

setContentView(R.layout.activity_main);

Log.d("==========","MainActivity onCreate finish");

}

@Override

protectedvoid onDestroy() {

Log.d("==========","MainActivity onDestroy");

super.onDestroy();

Log.d("==========","MainActivity onDestroy finish");

}

@Override

protectedvoid onPause() {

Log.d("==========","MainActivity onPause");

super.onPause();

Log.d("==========","MainActivity onPause finish");

}

@Override

protectedvoid onResume() {

Log.d("==========","MainActivity onResume");

super.onResume();

Log.d("==========","MainActivity onResume finish");

}

@Override

protectedvoid onStart() {

Log.d("==========","MainActivity onStart");

super.onStart();

Log.d("==========","MainActivity onStart finish");

}

@Override

protectedvoid onStop() {

Log.d("==========","MainActivity onStop");

super.onStop();

Log.d("==========","MainActivity onStop finish");

}

}

接下来是我们的FragmentA:

public class FragmentA extends Fragment {

@Override

publicvoid onAttach(Activity activity) {

super.onAttach(activity);

Log.d("==========","FragmentA onAttach");

}

@Override

publicvoid onActivityCreated(Bundle savedInstanceState) {

super.onActivityCreated(savedInstanceState);

Log.d("==========","FragmentA onActivityCreated");

}

@Override

publicvoid onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

Log.d("==========","FragmentA onCreate");

}

@Override

publicView onCreateView(LayoutInflater inflater, ViewGroup container,

BundlesavedInstanceState) {

Log.d("==========","FragmentA onCreateView");

returninflater.inflate(R.layout.fragment_main, container, false);

}

@Override

publicvoid onDestroy() {

super.onDestroy();

Log.d("==========","FragmentA onDestroy");

}

@Override

publicvoid onDestroyView() {

super.onDestroyView();

Log.d("==========","FragmentA onDestroyView");

}

@Override

publicvoid onDetach() {

super.onDetach();

Log.d("==========","FragmentA onDetach");

}

@Override

publicvoid onPause() {

super.onPause();

Log.d("==========","FragmentA onPause");

}

@Override

publicvoid onResume() {

super.onResume();

Log.d("==========","FragmentA onResume");

}

@Override

publicvoid onStart() {

super.onStart();

Log.d("==========","FragmentA onStart");

}

@Override

publicvoid onStop() {

super.onStop();

Log.d("==========","FragmentA onStop");

}

}

Fragment B和A类似,只是log不同。

开始测试。运行程序,当出现界面之后,关闭屏幕电源,然后再点亮屏幕,出现屏幕之后再旋转屏幕,最后按back退出程序。

查看Log:

======运行程序

04-21 16:54:05.689: D/==========(31589):MainActivity onCreate

04-21 16:54:05.699: D/==========(31589):FragmentA onAttach

04-21 16:54:05.699: D/==========(31589):FragmentA onCreate

04-21 16:54:05.709: D/==========(31589):FragmentA onCreateView

04-21 16:54:05.709: D/==========(31589):FragmentB onAttach

04-21 16:54:05.709: D/==========(31589):FragmentB onCreate

04-21 16:54:05.709: D/==========(31589):FragmentB onCreateView

04-21 16:54:05.709: D/==========(31589):MainActivity onCreate finish

04-21 16:54:05.709: D/==========(31589):MainActivity onStart

04-21 16:54:05.709: D/==========(31589):FragmentA onActivityCreated

04-21 16:54:05.709: D/==========(31589):FragmentB onActivityCreated

04-21 16:54:05.709: D/==========(31589):FragmentA onStart

04-21 16:54:05.709: D/==========(31589):FragmentB onStart

04-21 16:54:05.709: D/==========(31589):MainActivity onStart finish

04-21 16:54:05.709: D/==========(31589):MainActivity onResume

04-21 16:54:05.709: D/==========(31589):MainActivity onResume finish

04-21 16:54:05.709: D/==========(31589):FragmentA onResume

04-21 16:54:05.709: D/==========(31589):FragmentB onResume

======关闭屏幕

04-21 16:54:09.929: D/==========(31589):MainActivity onPause

04-21 16:54:09.989: D/==========(31589):FragmentA onPause

04-21 16:54:09.989: D/==========(31589):FragmentB onPause

04-21 16:54:09.989: D/==========(31589):MainActivity onPause finish

04-21 16:54:09.999: D/==========(31589):MainActivity onStop

04-21 16:54:09.999: D/==========(31589):FragmentA onStop

04-21 16:54:09.999: D/==========(31589):FragmentB onStop

04-21 16:54:09.999: D/==========(31589):MainActivity onStop finish

======再次点亮屏幕

04-21 16:54:22.099: D/==========(31589):MainActivity onStart

04-21 16:54:22.099: D/==========(31589):FragmentA onStart

04-21 16:54:22.099: D/==========(31589):FragmentB onStart

04-21 16:54:22.099: D/==========(31589):MainActivity onStart finish

04-21 16:54:22.109: D/==========(31589):MainActivity onResume

04-21 16:54:22.109: D/==========(31589):MainActivity onResume finish

04-21 16:54:22.109: D/==========(31589):FragmentA onResume

04-21 16:54:22.109: D/==========(31589):FragmentB onResume

======旋转屏幕(导致重新创建Activity和Fragment)

04-21 16:54:26.729: D/==========(31589):MainActivity onPause

04-21 16:54:26.729: D/==========(31589):FragmentA onPause

04-21 16:54:26.729: D/==========(31589):FragmentB onPause

04-21 16:54:26.729: D/==========(31589):MainActivity onPause finish

04-21 16:54:26.729: D/==========(31589):MainActivity onStop

04-21 16:54:26.729: D/==========(31589):FragmentA onStop

04-21 16:54:26.729: D/==========(31589):FragmentB onStop

04-21 16:54:26.729: D/==========(31589):MainActivity onStop finish

04-21 16:54:26.729: D/==========(31589):MainActivity onDestroy

04-21 16:54:26.729: D/==========(31589):FragmentA onDestroyView

04-21 16:54:26.729: D/==========(31589):FragmentA onDestroy

04-21 16:54:26.729: D/==========(31589):FragmentA onDetach

04-21 16:54:26.729: D/==========(31589):FragmentB onDestroyView

04-21 16:54:26.729: D/==========(31589):FragmentB onDestroy

04-21 16:54:26.729: D/==========(31589):FragmentB onDetach

04-21 16:54:26.729: D/==========(31589):MainActivity onDestroy finish

04-21 16:54:26.739: D/==========(31589):MainActivity onCreate

04-21 16:54:26.749: D/==========(31589):FragmentA onAttach

04-21 16:54:26.749: D/==========(31589):FragmentA onCreate

04-21 16:54:26.749: D/==========(31589):FragmentA onCreateView

04-21 16:54:26.749: D/==========(31589):FragmentB onAttach

04-21 16:54:26.749: D/==========(31589):FragmentB onCreate

04-21 16:54:26.749: D/==========(31589):FragmentB onCreateView

04-21 16:54:26.749: D/==========(31589):MainActivity onCreate finish

04-21 16:54:26.749: D/==========(31589):MainActivity onStart

04-21 16:54:26.749: D/==========(31589):FragmentA onActivityCreated

04-21 16:54:26.749: D/==========(31589):FragmentB onActivityCreated

04-21 16:54:26.749: D/==========(31589):FragmentA onStart

04-21 16:54:26.749: D/==========(31589):FragmentB onStart

04-21 16:54:26.749: D/==========(31589):MainActivity onStart finish

04-21 16:54:26.749: D/==========(31589):MainActivity onResume

04-21 16:54:26.749: D/==========(31589):MainActivity onResume finish

04-21 16:54:26.749: D/==========(31589):FragmentA onResume

04-21 16:54:26.749: D/==========(31589):FragmentB onResume

04-21 16:54:26.759: E/ViewRootImpl(31589):sendUserActionEvent() mView == null

======按Back退出程序

04-21 16:54:33.249: D/==========(31589):MainActivity onPause

04-21 16:54:33.249: D/==========(31589):FragmentA onPause

04-21 16:54:33.249: D/==========(31589):FragmentB onPause

04-21 16:54:33.249: D/==========(31589):MainActivity onPause finish

04-21 16:54:33.439:W/IInputConnectionWrapper(31589): showStatusIcon on inactive InputConnection

04-21 16:54:33.469: D/==========(31589):MainActivity onStop

04-21 16:54:33.469: D/==========(31589):FragmentA onStop

04-21 16:54:33.469: D/==========(31589):FragmentB onStop

04-21 16:54:33.469: D/==========(31589):MainActivity onStop finish

04-21 16:54:33.469: D/==========(31589):MainActivity onDestroy

04-21 16:54:33.469: D/==========(31589):FragmentA onDestroyView

04-21 16:54:33.469: D/==========(31589):FragmentA onDestroy

04-21 16:54:33.469: D/==========(31589):FragmentA onDetach

04-21 16:54:33.469: D/==========(31589):FragmentB onDestroyView

04-21 16:54:33.469: D/==========(31589):FragmentB onDestroy

04-21 16:54:33.469: D/==========(31589):FragmentB onDetach

04-21 16:54:33.469: D/==========(31589):MainActivity onDestroy finish

例子二 从代码中加载Fragment

接下来我们将上面的例子改一下,在点击Activity界面一个Button的时候添加两个Fragment。

我们将Activity的layout文件改成如下所示:

<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"

android:id="@+id/container"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="horizontal"

tools:context="com.example.androidtest.MainActivity"

tools:ignore="MergeRootFrame" >

<Button

android:id="@+id/btn"

android:layout_width="wrap_content"

android:layout_height="wrap_content" >

</Button>

</LinearLayout>

将MainActivity的onCreate函数改成如下:

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

Log.d("==========","MainActivity onCreate");

setContentView(R.layout.activity_main);

Buttonbtn = (Button) findViewById(R.id.btn);

btn.setOnClickListener(newOnClickListener() {

@Override

publicvoid onClick(View arg0) {

Fragmenta = new FragmentA();

FragmentTransactionft = getSupportFragmentManager().beginTransaction();

ft.add(R.id.container,a);

ft.commit();

}

});

Log.d("==========","MainActivity onCreate finish");

}

开始测试。运行程序,当出现界面之后,点击按钮,出现新的界面的之后,关闭屏幕电源,然后再点亮屏幕,出现屏幕之后再旋转屏幕,最后按back退出程序。

查看Log:

======运行程序

04-21 17:08:39.869: D/==========(2830):MainActivity onCreate

04-21 17:08:39.889: D/==========(2830):MainActivity onCreate finish

04-21 17:08:39.889: D/==========(2830):MainActivity onStart

04-21 17:08:39.889: D/==========(2830):MainActivity onStart finish

04-21 17:08:39.889: D/==========(2830):MainActivity onResume

04-21 17:08:39.889: D/==========(2830):MainActivity onResume finish

======点击按钮

04-21 17:08:46.039: D/==========(2830):FragmentA onAttach

04-21 17:08:46.039: D/==========(2830):FragmentA onCreate

04-21 17:08:46.039: D/==========(2830):FragmentA onCreateView

04-21 17:08:46.039: D/==========(2830): FragmentAonActivityCreated

04-21 17:08:46.039: D/==========(2830):FragmentA onStart

04-21 17:08:46.039: D/==========(2830):FragmentA onResume

======关闭屏幕

04-21 17:09:23.239: D/==========(2830):MainActivity onPause

04-21 17:09:23.329: D/==========(2830): FragmentAonPause

04-21 17:09:23.329: D/==========(2830):MainActivity onPause finish

04-21 17:09:23.429: D/==========(2830):MainActivity onStop

04-21 17:09:23.429: D/==========(2830):FragmentA onStop

04-21 17:09:23.429: D/==========(2830):MainActivity onStop finish

======再次点亮屏幕

04-21 17:09:46.779: D/==========(2830):MainActivity onStart

04-21 17:09:46.779: D/==========(2830):FragmentA onStart

04-21 17:09:46.779: D/==========(2830):MainActivity onStart finish

04-21 17:09:46.789: D/==========(2830): MainActivityonResume

04-21 17:09:46.789: D/==========(2830):MainActivity onResume finish

04-21 17:09:46.789: D/==========(2830):FragmentA onResume

======旋转屏幕

04-21 17:09:53.339: D/==========(2830):MainActivity onPause

04-21 17:09:53.339: D/==========(2830):FragmentA onPause

04-21 17:09:53.349: D/==========(2830):MainActivity onPause finish

04-21 17:09:53.349: D/==========(2830):MainActivity onStop

04-21 17:09:53.349: D/==========(2830):FragmentA onStop

04-21 17:09:53.349: D/==========(2830):MainActivity onStop finish

04-21 17:09:53.349: D/==========(2830):MainActivity onDestroy

04-21 17:09:53.349: D/==========(2830):FragmentA onDestroyView

04-21 17:09:53.349: D/==========(2830):FragmentA onDestroy

04-21 17:09:53.349: D/==========(2830):FragmentA onDetach

04-21 17:09:53.349: D/==========(2830):MainActivity onDestroy finish

04-21 17:09:53.359: D/==========(2830):FragmentA onAttach

04-21 17:09:53.359: D/==========(2830):FragmentA onCreate

04-21 17:09:53.359: D/==========(2830):MainActivity onCreate

04-21 17:09:53.379: D/==========(2830):MainActivity onCreate finish

04-21 17:09:53.379: D/==========(2830):MainActivity onStart

04-21 17:09:53.379: D/==========(2830):FragmentA onCreateView

04-21 17:09:53.379: D/==========(2830):FragmentA onActivityCreated

04-21 17:09:53.379: D/==========(2830):FragmentA onStart

04-21 17:09:53.379: D/==========(2830):MainActivity onStart finish

04-21 17:09:53.379: D/==========(2830):MainActivity onResume

04-21 17:09:53.379: D/==========(2830):MainActivity onResume finish

04-21 17:09:53.379: D/==========(2830):FragmentA onResume

04-21 17:09:53.399: E/ViewRootImpl(2830):sendUserActionEvent() mView == null

======按back退出程序

04-21 17:10:14.069: D/==========(2830):MainActivity onPause

04-21 17:10:14.069: D/==========(2830):FragmentA onPause

04-21 17:10:14.079: D/==========(2830):MainActivity onPause finish

04-21 17:10:14.249:W/IInputConnectionWrapper(2830): showStatusIcon on inactive InputConnection

04-21 17:10:14.269: D/==========(2830):MainActivity onStop

04-21 17:10:14.269: D/==========(2830):FragmentA onStop

04-21 17:10:14.269: D/==========(2830):MainActivity onStop finish

04-21 17:10:14.269: D/==========(2830):MainActivity onDestroy

04-21 17:10:14.269: D/==========(2830):FragmentA onDestroyView

04-21 17:10:14.269: D/==========(2830):FragmentA onDestroy

04-21 17:10:14.269: D/==========(2830):FragmentA onDetach

04-21 17:10:14.269: D/==========(2830):MainActivity onDestroy finish

例子三 Hide Fragment之后的生命周期

我们在main activity中添加两个按钮,一个add fragment,一个hidefragment

<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"

android:id="@+id/container"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="horizontal"

tools:context="com.example.androidtest.MainActivity"

tools:ignore="MergeRootFrame" >

<Button

android:id="@+id/btn1"

android:text="add Fragment"

android:layout_width="wrap_content"

android:layout_height="wrap_content" >

</Button>

<Button

android:id="@+id/btn2"

android:text="hide Fragment"

android:layout_width="wrap_content"

android:layout_height="wrap_content" >

</Button>

</LinearLayout>

修改MainActivity的onCreate函数

@Override

protectedvoid onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

Log.d("==========","MainActivity onCreate");

setContentView(R.layout.activity_main);

Buttonbtn1 = (Button) findViewById(R.id.btn1);

btn1.setOnClickListener(newOnClickListener() {

@Override

publicvoid onClick(View arg0) {

Log.d("==========","Add Fragment");

Fragmenta = new FragmentA();

FragmentTransactionft = getSupportFragmentManager().beginTransaction();

ft.add(R.id.container,a,"Fragment A");

ft.commit();

}

});

Buttonbtn2 = (Button) findViewById(R.id.btn2);

btn2.setOnClickListener(newOnClickListener() {

@Override

publicvoid onClick(View arg0) {

Log.d("==========","Hide Fragment");

FragmentTransactionft = getSupportFragmentManager().beginTransaction();

ft.hide(getSupportFragmentManager().findFragmentByTag("FragmentA"));

ft.commit();

}

});

Log.d("==========","MainActivity onCreate finish");

}

开始测试。运行程序,当出现界面之后,点击add Fragment,出现新的界面的之后,再点击hide Fragment,然后关闭屏幕,接着点亮屏幕。

查看Log:

======运行程序

04-21 17:18:53.069: D/==========(3974):MainActivity onCreate

04-21 17:18:53.079: D/==========(3974):MainActivity onCreate finish

04-21 17:18:53.079: D/==========(3974):MainActivity onStart

04-21 17:18:53.079: D/==========(3974):MainActivity onStart finish

04-21 17:18:53.079: D/==========(3974):MainActivity onResume

04-21 17:18:53.079: D/==========(3974):MainActivity onResume finish

======点击add Fragment

04-21 17:18:55.729: D/==========(3974): AddFragment

04-21 17:18:55.729: D/==========(3974):FragmentA onAttach

04-21 17:18:55.729: D/==========(3974):FragmentA onCreate

04-21 17:18:55.729: D/==========(3974):FragmentA onCreateView

04-21 17:18:55.729: D/==========(3974):FragmentA onActivityCreated

04-21 17:18:55.729: D/==========(3974):FragmentA onStart

04-21 17:18:55.729: D/==========(3974):FragmentA onResume

======点击hide Fragment

04-21 17:19:03.409: D/==========(3974):Hide Fragment

======关闭屏幕

04-21 17:19:20.349: D/==========(3974):MainActivity onPause

04-21 17:19:20.369: D/==========(3974):FragmentA onPause

04-21 17:19:20.369: D/==========(3974):MainActivity onPause finish

04-21 17:19:20.379: D/==========(3974):MainActivity onStop

04-21 17:19:20.379: D/==========(3974):FragmentA onStop

04-21 17:19:20.379: D/==========(3974):MainActivity onStop finish

======点亮屏幕

04-21 17:19:35.079: D/==========(3974):MainActivity onStart

04-21 17:19:35.079: D/==========(3974):FragmentA onStart

04-21 17:19:35.079: D/==========(3974):MainActivity onStart finish

04-21 17:19:35.089: D/==========(3974):MainActivity onResume

04-21 17:19:35.089: D/==========(3974):MainActivity onResume finish

04-21 17:19:35.089: D/==========(3974):FragmentA onResume

我们发现虽然我们的Fragment被hide起来了,但是因为他没有被移除掉,所以他的生命周期还是会被宿主Activity影响。

时间: 2024-08-05 08:01:12

Fragment(四)Fragment生命周期分析(转)的相关文章

Fragment和Activity生命周期以及横竖屏切换对生命周期的影响

Fragment生命周期图解,fragment和activity生命周期对比 生命周期变化 : 切换到该Fragment 05-21 14:26:35.095: D/FragmentDemo(7649): onAttach 05-21 14:26:35.095: D/FragmentDemo(7649): onCreate 05-21 14:26:35.095: D/FragmentDemo(7649): onCreateView 05-21 14:26:35.100: D/FragmentDe

ViewController的生命周期分析和使用

ViewController的生命周期分析和使用 一.结构 按结构可以对iOS的所有ViewController分成两类: 1.主要用于展示内容的ViewController,这种ViewController主要用于为用户展示内容,并与用户交互,如UITableViewController,UIViewController. 2.用于控制和显示其他ViewController的ViewController.这种ViewController一般都是一个ViewController的容器.如UINa

12、Cocos2dx 3.0游戏开发找小三之3.0中的生命周期分析

重开发人员的劳动成果.转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/27706303 生命周期分析 在前面文章中我们执行了第一个 Cocos2d-x 游戏,同一时候也介绍了控制游戏生命周期的 AppDelegate 文件. 以下我们将结合一些游戏调试经常使用的技巧以及VS工具调试的方法来分析 Cocos2d-x 程序的生命周期. VS工具调试 1.查看内存窗体 2.查看输出窗体 3.假设程序崩溃查看调用堆栈窗体 打开项目

ViewPager+RadioButton+FragmentPagerAdapter实现导航fragment生命周期分析

(1)刚开始进来: 01-21 03:18:16.264: I/DD(1736): DoorManagerFragment======onAttach====== 01-21 03:18:16.264: I/DD(1736): DoorManagerFragment======onCreate====== 01-21 03:18:16.268: I/DD(1736): DoorManagerFragment======onCreateView====== 01-21 03:18:16.272:

Fragment创建及其生命周期

Fragments的生命周期 每一个fragments 都有自己的一套生命周期回调方法和处理自己的用户输入事件. 对应生命周期可参考下图: 创建片元(Creating a Fragment) To create a fragment, you must create a subclass of Fragment (or an existing subclass of it). The Fragment class has code that looks a lot like an Activit

fragment hide/show 生命周期

Fragment的使用越来越普遍了,掌握它的生命周期以及注意事项时非常有必要的,首先 All subclasses of Fragment must include a public empty constructor. The framework will often re-instantiate a fragment class when needed, in particular during state restore, and needs to be able to find this

Android Fragment详解(二):Fragment创建及其生命周期

Fragments的生命周期 每一个fragments 都有自己的一套生命周期回调方法和处理自己的用户输入事件. 对应生命周期可参考下图: 创建片元(Creating a Fragment) To create a fragment, you must create a subclass of Fragment (or an existing subclass of it). The Fragment class has code that looks a lot like an Activit

Vue学习系列(四)——理解生命周期和钩子

前言 在上一篇中,我们对平时进行vue开发中遇到的常用指令进行归类说明讲解,大概已经学会了怎么去实现数据绑定,以及实现动态的实现数据展示功能,运用指令,可以更好更快的进行开发.而在这一篇中,我们将通过实例,探究vue的生命周期. 万物皆有灵,世间万物都拥有灵魂,小到山河湖海,花草树木,蚂蚁到人类,以及所有的动植物,大到地球星空和宇宙,都拥有灵魂,可以说他们都是有生命的,只是他们的生命形态是我们人类所不能理解的存在.在生产中,生命周期通俗来讲,就是从自然中来回到自然中去的全过程,也就是从采集材料设

Unity3D脚本(MonoBehaviour)生命周期分析

欢迎来到unity学习.unity培训.unity企业培训教育专区,这里有很多U3D资源.U3D培训视频.U3D教程.U3D常见问题.U3D项目源码,我们致力于打造业内unity3d培训.学习第一品牌. 场景中有2个物体:A,B 每个物体上绑定2个脚本:A,B 初始化log: Object : A , Script : B , Message : Awake Object : A , Script : B , Message : OnEnable Object : A , Script : A