使用FragmentPagerAdapter时Fragment的生命周期

FragmentPagerAdapter 会保存在内存中保存Fragment的实例,当ViewPagerFragment的数量较多时,建议使用FragmentStatePagerAdapter

当使用FragmentPagerAdapter时Fragment的生命周期怎么走呢?(使用的是v4包下的Fragment)

当viewpager加载时,会加载当前页跟相邻页的fragment(如果有),那么此时,Fragment的log日志是这样的

I/fragment: onAttach: 
I/fragment: onCreate: 
I/fragment: onAttach: 
I/fragment: onCreate: 
I/fragment: onCreateView: +position 1
I/fragment: onActivityCreated: +position 1
I/fragment: onCreateView: +position 0
I/fragment: onActivityCreated: +position 0
I/fragment: onStart: 0
I/fragment: onResume: 0
I/fragment: onStart: 1
I/fragment: onResume: 1

我们看到,有两个Fragment的生命周期都走了,而他们基本上算是交替执行的。那么当我们滑动到第三个页面再划回第一个页面呢?生命周期又会怎么走?
肯定的第三个页面和第四个页面的onAttachonCreate,onCreateView,onActivityCreate,onStart,onResume生命周期都会执行。那么顺序是怎么样的呢?我们来看下log日志。

//以下是滑动到Fragment3时走的的生命周期
I/fragment: onAttach: 
I/fragment: onCreate: 
I/fragment: onCreateView: +position 2
I/fragment: onActivityCreated: 2
I/fragment: onStart: 2
I/fragment: onResume: 2

I/fragment: onAttach: 
I/fragment: onCreate: 

I/fragment: onPause: 0
I/fragment: onStop: 0
I/fragment: onDestroyView: 0

I/fragment: onCreateView: +position 3
I/fragment: onActivityCreated: 3
I/fragment: onStart: 3
I/fragment: onResume: 3

//以下是滑动到fragment0的
I/fragment: onCreateView: +position 0
I/fragment: onActivityCreated: 0
I/fragment: onPause: 3
I/fragment: onStop: 3
I/fragment: onDestroyView: 3
I/fragment: onStart: 0
I/fragment: onResume: 0
I/fragment: onPause: 2
I/fragment: onStop: 2
I/fragment: onDestroyView: 2

我们发现Fragment2的生命周期先走到了onResume,之后Fragment0走到了onDestoryView中,而当我们重新滑到Fragment0的时候,Fragment0的生命周期是从onCreateView开始走的,并没有走onCreate方法。

使用FragmentStatePagerAdapter时Fragment的生命周期

当使用FragmentStatePagerAdapter时,第一次走的生命周期跟FragmentPagerAdapter是一样的。但是当我们滑动到第三个Fragment(即:Fragment 2)再划回第一个Fragment(Fragment 0)呢?
生命周期如下:

I/fragment: onAttach: 
I/fragment: onCreate: 
I/fragment: onCreateView: +position 2
I/fragment: onActivityCreated: 2
I/fragment: onStart: 2
I/fragment: onResume: 2

I/fragment: onAttach: 
I/fragment: onCreate: 

I/fragment: onPause: 0
I/fragment: onStop: 0
I/fragment: onDestroyView: 0
I/fragment: onDestroy: 0
I/fragment: onDetach: 0

I/fragment: onCreateView: +position 3
I/fragment: onActivityCreated: 3
I/fragment: onStart: 3
I/fragment: onResume: 3
I/fragment: onAttach: 
I/fragment: onCreate: 
I/fragment: onPause: 3
I/fragment: onStop: 3
I/fragment: onDestroyView: 3
I/fragment: onDestroy: 3
I/fragment: onDetach: 3

I/fragment: onCreateView: +position 0
I/fragment: onActivityCreated: 0
I/fragment: onStart: 0
I/fragment: onResume: 0

I/fragment: onPause: 2
I/fragment: onStop: 2
I/fragment: onDestroyView: 2
I/fragment: onDestroy: 2
I/fragment: onDetach: 2

我们可以看到,当我们滑动到第三个Fragment(Fragment 2)时,第一个Fragment(Fragment 0)的生命周期已经走到了onDetach,此时Fragment0已经和activity解绑。也就不会在内存中保存Fragment的实例。

分析

通过上面的Fragment的生命周期我们可以看到,当ViewPager使用FragmentPagerAdapter时滑动viewpager,Fragment并不会跟acvitity解绑,并且划回该Fragment时,onCreate方法也不会执行。FragmentStatePagerAdapter时,Fragment已经跟activity解绑了,重新划回该Fragment时,Fragment的生命周期会全部走一遍。

因此当我们在Fragment的onCreate方法中执行的网络请求,那么在FragmentPagerAdapter中,该网络请求只会执行一次,而FragmentStatePagerAdapter则会每次都得到执行。


Magicer
246 声望11 粉丝

[链接]