https://blog.csdn.net/mvpstevenlin/article/details/51136396
问题原因:
在onDestroy函数中,删除掉了super.onDestroy()代码所导致的问题。
04-13 19:26:26.529: E/AndroidRuntime(15242): FATAL EXCEPTION: main
04-13 19:26:26.529: E/AndroidRuntime(15242): Process: xxx, PID: 15242
04-13 19:26:26.529: E/AndroidRuntime(15242): android.support.v4.app.SuperNotCalledException: Fragment MakeFragment{3d3c209c #1 id=0x7f090118} did not call through to super.onDestroy()
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.support.v4.app.Fragment.performDestroy(Fragment.java:1722)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1056)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.support.v4.app.FragmentManagerImpl.removeFragment(FragmentManager.java:1201)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:639)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:440)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.os.Handler.handleCallback(Handler.java:739)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.os.Handler.dispatchMessage(Handler.java:95)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.os.Looper.loop(Looper.java:135)
04-13 19:26:26.529: E/AndroidRuntime(15242): at android.app.ActivityThread.main(ActivityThread.java:5312)
04-13 19:26:26.529: E/AndroidRuntime(15242): at java.lang.reflect.Method.invoke(Native Method)
04-13 19:26:26.529: E/AndroidRuntime(15242): at java.lang.reflect.Method.invoke(Method.java:372)
04-13 19:26:26.529: E/AndroidRuntime(15242): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:901)
04-13 19:26:26.529: E/AndroidRuntime(15242): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:696)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
解决方法:
加上super.onDestroy()代码即可解决问题。
@Override
public void onDestroy() {
super.onDestroy();
...
}
- 1
- 2
- 3
- 4
- 5
相同的问题,在重写 onStart()、onStop()、onResume()、onPause()、onDestroy() 等函数时也要留意此问题。