java.lang.IllegalStateException: No activity

来源:互联网 发布:单片机uart是什么意思 编辑:程序博客网 时间:2024/05/01 17:51

错误提示:

Java.lang.IllegalStateException: No activity
at Android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1075)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1070)
at android.support.v4.app.FragmentManagerImpl.dispatchActivityCreated(FragmentManager.java:1861)
at android.support.v4.app.Fragment.performActivityCreated(Fragment.java:1474)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:931)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1088)

.......

这个问题是在解决上一篇文章(http://blog.csdn.net/leewenjin/article/details/19409863)中指出的问题后出现的。问题解决方法是参考文章:

http://stackoverflow.com/questions/15207305/getting-the-error-java-lang-illegalstateexception-activity-has-been-destroyed

bug出现的原理问题及解决方法是
This seems to be a bug in the newly added support for nested fragments. Basically, the child FragmentManager ends up with a broken internal state when it is detached from the activity. A short-term workaround that fixed it for me is to add the following to onDetach() of every Fragment which you call getChildFragmentManager() on:

解决方法重写onDetach()

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. @Override  
  2.     public void onDetach() {  
  3.         super.onDetach();  
  4.         try {  
  5.             Field childFragmentManager = Fragment.class.getDeclaredField("mChildFragmentManager");  
  6.             childFragmentManager.setAccessible(true);  
  7.             childFragmentManager.set(thisnull);  
  8.   
  9.         } catch (NoSuchFieldException e) {  
  10.             throw new RuntimeException(e);  
  11.         } catch (IllegalAccessException e) {  
  12.             throw new RuntimeException(e);  
  13.         }  
  14.       
  15.     }  

其中的Field 是

Open Declarationjava.lang.reflect.Field

引起bug的原因
If you look at the implementation of Fragment, you'll see that when moving to the detached state, it'll reset its internal state. However, it doesn't reset mChildFragmentManager (this is a bug in the current version of the support library). This causes it to not reattach the child fragment manager when the Fragment is reattached, causing the exception you saw.


0 0