国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Android Fragment生命周期深入探究

瀏覽:17日期:2022-09-27 15:49:43

Fragment是Android中的重要組件,在Android 3.0的時候添加進來。

關于Fragment的生命周期,我相信了解過的開發(fā)人員都應該把以下方法脫口而出:onAttach, onCreate, onCreateView, onViewCreated, onActivityCreated, onStart, onResume, onPause, onStop, onDestroyView, onDestroy, onDetach.

當Fragment以靜態(tài)的方式,即通過在布局文件中以其它控件的方式設置時,它的生命周期隨所在Activity的生命周期而發(fā)生變化。此時其生命周期的方法調用過程是這樣的:

1,當首次展示布局頁面時,其生命周期方法調用的順序是:

Android Fragment生命周期深入探究

2,而當關閉手機屏幕或者手機屏幕變暗時,其其生命周期方法調用的順序是:

Android Fragment生命周期深入探究

3,當再次對手機屏幕解鎖或者手機屏幕變亮時,其生命周期方法調用的順序是:

Android Fragment生命周期深入探究

4,而當對當前Fragment所在屏幕按返回鍵時,其生命周期方法調用的順序是:

1 01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onPause2 01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onStop3 01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onDestroyView4 01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onDestroy5 01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onDetach

但是當使用FragmentManager動態(tài)的管理Fragment并且涉及到是否addToBackStack時,其生命周期的展現(xiàn)就略微顯得有些復雜了。但是還沒有復雜到無法理解。

好,下面,我們就探究一下這些問題。

首先,我們重寫了兩個Fragment,主要是重寫了它們的生命周期方法,通過在其生命周期方法中打印出Log的方式來顯示其方法的調用。

兩個類分別是:

package com.yeepay.fraglifecircletest.frag;import android.app.Activity;import android.app.Fragment;import android.os.Bundle;import android.util.Log;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import com.yeepay.fraglifecircletest.R;public class FragA extends Fragment { private static final String TAG = FragA.class.getSimpleName(); @Override public void onAttach(Activity activity) {super.onAttach(activity);Log.i(TAG, 'onAttach'); } @Override public void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);Log.i(TAG, 'onCreate'); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {Log.i(TAG, 'onCreateView');return inflater.inflate(R.layout.fragment_test_a, null, false); } @Override public void onViewCreated(View view, Bundle savedInstanceState) {Log.i(TAG, 'onViewCreated');super.onViewCreated(view, savedInstanceState); } @Override public void onDestroy() {Log.i(TAG, 'onDestroy');super.onDestroy(); } @Override public void onDetach() {Log.i(TAG, 'onDetach');super.onDetach(); } @Override public void onDestroyView() {Log.i(TAG, 'onDestroyView');super.onDestroyView(); } @Override public void onStart() {Log.i(TAG, 'onStart');super.onStart(); } @Override public void onStop() {Log.i(TAG, 'onStop');super.onStop(); } @Override public void onResume() {Log.i(TAG, 'onResume');super.onResume(); } @Override public void onPause() {Log.i(TAG, 'onPause');super.onPause(); } @Override public void onActivityCreated(Bundle savedInstanceState) {Log.i(TAG, 'onActivityCreated');super.onActivityCreated(savedInstanceState); }}FragA.java

package com.yeepay.fraglifecircletest.frag;import android.app.Activity;import android.app.Fragment;import android.os.Bundle;import android.util.Log;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import com.yeepay.fraglifecircletest.R;public class FragB extends Fragment { private static final String TAG = FragB.class.getSimpleName(); @Override public void onAttach(Activity activity) {super.onAttach(activity);Log.i(TAG, 'onAttach'); } @Override public void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);Log.i(TAG, 'onCreate'); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {Log.i(TAG, 'onCreateView');return inflater.inflate(R.layout.fragment_test_b, null, false); } @Override public void onViewCreated(View view, Bundle savedInstanceState) {Log.i(TAG, 'onViewCreated');super.onViewCreated(view, savedInstanceState); } @Override public void onDestroy() {Log.i(TAG, 'onDestroy');super.onDestroy(); } @Override public void onDetach() {Log.i(TAG, 'onDetach');super.onDetach(); } @Override public void onDestroyView() {Log.i(TAG, 'onDestroyView');super.onDestroyView(); } @Override public void onStart() {Log.i(TAG, 'onStart');super.onStart(); } @Override public void onStop() {Log.i(TAG, 'onStop');super.onStop(); } @Override public void onResume() {Log.i(TAG, 'onResume');super.onResume(); } @Override public void onPause() {Log.i(TAG, 'onPause');super.onPause(); } @Override public void onActivityCreated(Bundle savedInstanceState) {Log.i(TAG, 'onActivityCreated');super.onActivityCreated(savedInstanceState); }}FragB.java

1,當我們通過以下方式添加FragA時,

1 FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();2 fragA = new FragA();3 fragmentTransaction.replace(R.id.frag_container, fragA, fragNames[0]);4 fragmentTransaction.commit();

它的生命周期展示方式是同在布局文件中靜態(tài)設置的表現(xiàn)一模一樣的,這里不再詳細展開,大家可以查看一下以上內容。

2,當我們以如下方式展示FragA并且沒有addToBackStack時,

@Override public void onClick(View v) {FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();switch (v.getId()) { case R.id.button1:if (fragA == null) { fragA = new FragA(); fragmentTransaction.replace(R.id.frag_container, fragA, fragNames[0]);// fragmentTransaction.addToBackStack(fragNames[0]);} else { Fragment fragment = fragmentManager.findFragmentByTag(fragNames[0]); fragmentTransaction.replace(R.id.frag_container, fragment, fragNames[0]);}break; case R.id.button2:if (fragB == null) { fragB = new FragB(); fragmentTransaction.replace(R.id.frag_container, fragB, fragNames[1]);// fragmentTransaction.addToBackStack(fragNames[1]);} else { Fragment fragment = fragmentManager.findFragmentByTag(fragNames[1]); fragmentTransaction.replace(R.id.frag_container, fragment, fragNames[1]);}break; default:break;}fragmentTransaction.commit(); }

FragA生命周期調用順序是:

Android Fragment生命周期深入探究

此時,如果再點擊另外一個按鈕B,將FragB展示出來,F(xiàn)ragA和FragB的生命周期展示方式是:

Android Fragment生命周期深入探究

可以看到,F(xiàn)ragA調用順序為onPause, onStop, onDestroyView, onDestroy, onDetach.這說明,F(xiàn)ragA已經被FragmentManager完全拋棄了,取而代之的是FragB的完全展現(xiàn)。而如果此時按返回鍵的話,F(xiàn)ragB的生命周期也將是onPause, onStop, onDestroyView, onDestroy, onDetach。這說明,在添加Fragment時如果沒有調用addToBackStack方式的話,當FragmentManager更換Fragment時,是不保存Fragment的狀態(tài)的。

3,下面我們在替換Fragment時順便addToBackStack,則其生命周期展現(xiàn)方式是:

replace FragA and addToBackStack########################################################################################01-13 17:08:43.359 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onAttach01-13 17:08:43.359 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onCreate01-13 17:08:43.359 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onCreateView01-13 17:08:43.359 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onViewCreated01-13 17:08:43.359 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onActivityCreated01-13 17:08:43.359 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onStart01-13 17:08:43.359 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onResume

可以看得出來,此時的生命周期方法調用是跟沒有addToBackStack時沒有任何區(qū)別的。

然后通過點擊按鈕B,使用FragB來替換FragA,此時FragA和FragB的生命周期方法調用順序是:

and then replace FragB and addToBackStack&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onPause01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onStop01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onDestroyView01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onAttach01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onCreate01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onCreateView01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onViewCreated01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onActivityCreated01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onStart01-13 17:08:46.959 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onResume

由此可以看出,F(xiàn)ragA生命周期方法只是調用到了onDestroyView,而onDestroy和onDetach則沒有被調用,這說明FragA的界面已經被銷毀了,但是FragmentManager并沒有完全銷毀FragA,F(xiàn)ragA依然有狀態(tài)保存在FragmentManager里面。

然后再點擊按鈕A,使用FragA來替換當前顯示的FragB,此時FragA和FragB的生命周期方法調用順序為:

and then replace FragA again&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onPause01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onStop01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragB﹕ onDestroyView01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onCreateView01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onViewCreated01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onActivityCreated01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onStart01-13 17:08:51.869 3102-3102/com.yeepay.fraglifecircletest I/FragA﹕ onResume

可以看到,F(xiàn)ragB的生命方法調用順序是跟FragB替換FragA時FragA的調用順序一致的,作用就是只銷毀了視圖,但是依然保留了Fragment的狀態(tài)。而此時FragA的調用則值得注意,此時FragA直接從onCreateView調起,也就是說只是重新創(chuàng)建了視圖,而依然使用上次被替換時的Fragment狀態(tài)。

OK,說到此時,是否對Fragment的生命周期方法調用在是否addToBackStack時不同有所更加深入的了解了呢?

好吧,最后一個問題。是關于Fragment在FragmentManager管理時,show和hide時的生命周期方法調用。

此時的調用實現(xiàn)方式為:

FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();switch (v.getId()) { case R.id.button1:hideAllFrags(fragmentTransaction);if (fragA == null) { fragA = new FragA(); fragmentTransaction.add(R.id.frag_container, fragA, fragNames[0]); fragmentTransaction.addToBackStack(fragNames[0]);} else { fragmentTransaction.show(fragA);}break; case R.id.button2:hideAllFrags(fragmentTransaction);if (fragB == null) { fragB = new FragB(); fragmentTransaction.add(R.id.frag_container, fragB, fragNames[1]); fragmentTransaction.addToBackStack(fragNames[1]);} else { fragmentTransaction.show(fragB);}break; default:break;}fragmentTransaction.commit();

細心的話可以發(fā)現(xiàn),在展示Fragment時,我們使用了方法add而非上面用的replace。而且直接addToBackStack。其實這也可以理解,你想,F(xiàn)ragmentManager在show或者hide時,肯定是已經存在的,或者如果沒有的話,需要添加進來Fragment。這便是在show和hide時,需要注意的地方,即使用add和addToBackStack方法。

在點擊按鈕A時,F(xiàn)ragA的調用順序為:

01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/hideAllFrags﹕ hideAllFrags01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onAttach01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onCreate01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onCreateView01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onViewCreated01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onActivityCreated01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onStart01-15 16:57:20.390 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onResume

可以看出沒有什么不同于以上所言的部分。

然后,點擊按鈕B時,F(xiàn)ragA和FragB的調用順序為:

01-15 16:57:23.360 9225-9225/com.yeepay.fraglifecircletest I/hideAllFrags﹕ hideAllFrags01-15 16:57:23.360 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onAttach01-15 16:57:23.360 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onCreate01-15 16:57:23.360 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onCreateView01-15 16:57:23.370 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onViewCreated01-15 16:57:23.370 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onActivityCreated01-15 16:57:23.370 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onStart01-15 16:57:23.370 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onResume

可以看出,F(xiàn)ragA并沒有調用生命周期方法,這說明是展示FragB時,F(xiàn)ragA的生命周期并沒有發(fā)生變化。而FragB的生命周期與初次點擊按鈕A時FragA的生命周期方法相同。

然后再繼續(xù)點擊按鈕A和B,此時打印出來的log為:

1 01-15 16:57:25.220 9225-9225/com.yeepay.fraglifecircletest I/hideAllFrags﹕ hideAllFrags2 01-15 16:57:44.990 9225-9225/com.yeepay.fraglifecircletest I/hideAllFrags﹕ hideAllFrags3 01-15 16:57:47.350 9225-9225/com.yeepay.fraglifecircletest I/hideAllFrags﹕ hideAllFrags4 01-15 16:57:48.020 9225-9225/com.yeepay.fraglifecircletest I/hideAllFrags﹕ hideAllFrags

這說明在FragA和FragB添加進BackStack之后無論如何地show或者hide,它們的生命周期不再發(fā)生變化。

而當屏幕上鎖或變暗,然后再解鎖或者變亮時,F(xiàn)ragA和FragB的生命周期方法調用順序為:

when screen is locked:###########################################################################################01-15 16:58:36.840 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onPause01-15 16:58:36.840 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onPause01-15 16:58:36.870 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onStop01-15 16:58:36.880 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onStopwhen screen is unlocked:##########################################################################################01-15 17:05:01.850 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onStart01-15 17:05:01.850 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onStart01-15 17:05:01.870 9225-9225/com.yeepay.fraglifecircletest I/FragA﹕ onResume01-15 17:05:01.870 9225-9225/com.yeepay.fraglifecircletest I/FragB﹕ onResume

可以看得出來,兩個Fragment都調用了onPause, onStop, onStart, onResume。而且FragA的調用要在FragB之前,這說明跟他們添加進BackStack的順序有關。

以上就是我對Fragment在被FragmentManager管理時,其生命周期方法調用順序的探究,大家覺得如果有什么地方不嚴謹或者不準確的地方,歡迎在留言處告知。示例工程下載地址為:FragLifeCircleTest

標簽: Android
相關文章:
主站蜘蛛池模板: 美国三级大片 | 久久免费看 | 国产精品欧美一区二区三区 | 欧美成人性色生活片免费在线观看 | 久草视频免费 | 亚洲免费人成在线视频观看 | 99视频在线播放 | 亚洲欧美一区二区三区在线播放 | 九九九九在线视频播放 | 4四虎44虎www在线影院麻豆 | 毛片免费在线观看网址 | 免费在线视频成人 | 欧美成本人视频 | 福利片免费一区二区三区 | 久草视频福利在线 | 亚洲国产成人久久一区www | 真人一级毛片免费观看视频 | 九九综合九九 | 国产成人精品免费视频大 | 国产午夜免费视频片夜色 | 99精品久久久久久久免费看蜜月 | 欧美野外性k8播放性迷宫 | 国产欧美日本 | 亚洲天堂视频在线免费观看 | 欧美日产国产亚洲综合图区一 | 五月色婷婷综合开心网亚 | 亚洲国产成a人v在线 | 亚洲欧美在线综合一区二区三区 | 一级片免费视频 | 午夜看片网站 | 久久视频在线视频 | 精品一久久香蕉国产线看播放 | 女高中生被cao到哭视频 | 最近韩国日本免费免费版 | 亚洲视频网站在线观看 | 免费观看成为人视频 | 农村三级孕妇视频在线 | 欧美一级欧美一级高清 | 亚洲国产二区三区 | 亚洲成人777 | 国产激情一区二区三区在线观看 |