2014-09-13 16 views
0

我试图描述的情况,我有活动与listview1和容器,我保持片段。 它看起来像这样enter image description hereclasscastexception提交后尝试调用片段中的方法

黄色是带碎片的容器。 开始时,应用程序启动,在黄色的容器中,我保留与另一个例如listView2的片段。当我点击listView1时,黄色部分会出现另一个显示图片的片段。当我想关闭这张图片时,listview2应该出现在黄色的一面,并且一切都很好,直到这段代码。

这里我做的黄色的容器中的替换操作之后,我试着重新创建listview2 在更换新的片段

public void backToList() 
    { 
     FragmentTransaction fragmentTransaction = fragManager.beginTransaction(); 

     Fragment fragment =null; 

     fragment = new Presence_Fragment(); 


     fragmentTransaction.replace(R.id.main_screen_fragment_container, fragment); 
     fragmentTransaction.commit(); 
     createProperlyListViewInPresenceOrAktywnosciFragment(); 
    } 

,这里是从片段调用CreateListViewMethod()方法

public void createProperlyListViewInPresenceOrAktywnosciFragment() 
    { 

      Presence_Fragment presence_Fragment = (Presence_Fragment) fragManager.findFragmentById(R.id.main_screen_fragment_container); 
      presence_Fragment.CreateListView(); 


    } 

的logcat的:

09-13 00:52:35.653: E/AndroidRuntime(2980): FATAL EXCEPTION: main 
09-13 00:52:35.653: E/AndroidRuntime(2980): Process: com.example.kinder, PID: 2980 
09-13 00:52:35.653: E/AndroidRuntime(2980): java.lang.ClassCastException: com.example.kinder.ChildBioFragment cannot be cast to com.example.kinder.Presence_Fragment 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.example.kinder.MainScreen.createProperlyListViewInPresenceOrAktywnosciFragment(MainScreen.java:175) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.example.kinder.MainScreen.backToList(MainScreen.java:216) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.example.kinder.ChildBioFragment$1.onClick(ChildBioFragment.java:47) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.view.View.performClick(View.java:4445) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.view.View$PerformClick.run(View.java:18446) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.os.Handler.handleCallback(Handler.java:733) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.os.Handler.dispatchMessage(Handler.java:95) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.os.Looper.loop(Looper.java:136) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.app.ActivityThread.main(ActivityThread.java:5139) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at java.lang.reflect.Method.invokeNative(Native Method) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at java.lang.reflect.Method.invoke(Method.java:515) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at dalvik.system.NativeStart.main(Native Method) 

logcat在容器中寻找像我仍然保留旧片段,但它不可能我已经用Presence_Fragment替换ChildBioFragment并提交。我想从Presence_fragment调用方法,所以这个代码有什么问题

回答

0

你在这里做一个假设:即commit()立即执行。但是,情况并非如此。它按照文档异步执行(在UI线程上):

提交不会立即发生;它将被安排在主线程上工作,在下次线程准备就绪时完成。执行同步提交

一种方法是调用下面的右后:

fragmentManager.executePendingTransactions(); 

参考the docs的细节:

如果你想立即执行任何此类未决操作[片段事务],您可以调用此函数(仅限于主线程)来执行此操作。

或者,只保留对您实例化的存在片段的引用(而不是从管理器中检索它)。请记住commit()是异步运行的,所以在提交后不要试图触及它的任何视图。

+0

是啊这是我放在logcat上的问题的来源,当ChildBioFragment中的onDetach方法被调用,并且当createProperlyListViewInPresenceOrAktywnosciFragment被调用时,首先被调用createProperly ..方法,然后onDetach,我的解决方案是重新创建Presence_Fragment中的列表,作品 – MyWay 2014-09-13 13:10:32

相关问题