2013-07-22 100 views
2

我有3个片段选项卡,片段1,片段2和片段3。我在fragment2中创建了另一个片段选项卡。问题是每当我重新选择包含片段选项卡的片段2时,我的应用会崩溃,并显示如下所示的LOGCAT。我在这个链接Getting the error "Java.lang.IllegalStateException Activity has been destroyed" when using tabs with ViewPager上按照一个问题在计算器上,但它似乎也不工作。另外,我是否正在导入正确的库“import java.lang.reflect.Field;”?FragmentTabHost“活动已被破坏”

fragment2.java

import com.actionbarsherlock.app.SherlockFragment; 
import android.os.Bundle; 
import android.support.v4.app.FragmentTabHost; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 

public class Fragment2 extends SherlockFragment{ 
    private FragmentTabHost mTabHost; 

     @Override 
     public View onCreateView(LayoutInflater inflater, ViewGroup container, 
       Bundle savedInstanceState) { 

      mTabHost = new FragmentTabHost(getSherlockActivity()); 
      mTabHost.setup(getSherlockActivity(), getChildFragmentManager(), R.layout.fragmenttab2); 

      mTabHost.addTab(mTabHost.newTabSpec("simple").setIndicator("Simple"), 
        Fragment1.class, null); 
      mTabHost.addTab(mTabHost.newTabSpec("contacts").setIndicator("Contacts"), 
        Fragment2.class, null); 
      mTabHost.addTab(mTabHost.newTabSpec("custom").setIndicator("Custom"), 
        Fragment3.class, null); 

      return mTabHost; 
     } 

     @Override 
     public void onDestroyView() { 
      super.onDestroyView(); 
      mTabHost = null; 
     } 


} 

的logcat:

07-22 16:18:50.668: E/AndroidRuntime(29774): FATAL EXCEPTION: main 
07-22 16:18:50.668: E/AndroidRuntime(29774): java.lang.IllegalStateException: Activity has been destroyed 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.FragmentManagerImpl.enqueueAction(FragmentManager.java:1342) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.BackStackRecord.commitInternal(BackStackRecord.java:595) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.BackStackRecord.commit(BackStackRecord.java:574) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.FragmentTabHost.onAttachedToWindow(FragmentTabHost.java:278) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.view.View.dispatchAttachedToWindow(View.java:9953) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:2198) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:2206) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.view.ViewGroup.addViewInner(ViewGroup.java:3376) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.view.ViewGroup.addView(ViewGroup.java:3208) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.view.ViewGroup.addView(ViewGroup.java:3165) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.view.ViewGroup.addView(ViewGroup.java:3145) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:922) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1088) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1444) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:429) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.os.Handler.handleCallback(Handler.java:605) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.os.Handler.dispatchMessage(Handler.java:92) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.os.Looper.loop(Looper.java:137) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at android.app.ActivityThread.main(ActivityThread.java:4507) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at java.lang.reflect.Method.invokeNative(Native Method) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at java.lang.reflect.Method.invoke(Method.java:511) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:980) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:747) 
07-22 16:18:50.668: E/AndroidRuntime(29774): at dalvik.system.NativeStart.main(Native Method) 

回答

0

当编写这些代码:

Field childFragmentManager = Fragment2.class.getDeclaredField("mChildFragmentManager"); 

意味着你婉得到提起你Fragment2声明。

我可以在Fragment2中看到mChildFragmentManager字段。

如果您确定该栏的超类被声明,你应该使用 Fragment2.class.getField

+0

尝试更换Fragment2.class.getDeclaredField( “mChildFragmentManager”);通过Fragment2.class.getField(“mChildFragmentManager”); – kvh

+0

对不起,尝试getField – kvh

+0

我的logcat出现了一些错误。嗯,任何解决方法? –

0

试试这个你childFragmentManager

childeFragmentManager = getChildFragmentManager().

有人支持加入在4.2之前版本库中嵌套的片段在此之前不受支持。

来源 http://developer.android.com/about/versions/android-4.2.html#NestedFragments

+0

对不起,请问我该把这个放在哪里? –

+0

对不起,你编辑了你的问题。在上次编辑中,您使用反射('Field')在'onDetach()'中查找'FragmentManager'。所以,而不是使用这个。我不知道你是如何在片段中添加子片段的。但不要使用'getFragmentManager()'在片段中添加片段,而是使用'getChildFragmentManager()'。 – vKashyap