31

这是我的堆栈跟踪:

FATAL EXCEPTION: main
java.lang.NullPointerException
at com.example.test.fragments.LoadingFragment$1.run(LoadingFragment.java:66)
at android.os.Handler.handleCallback(Handler.java:725)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5041)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)

我的片段的第 66 行:

FragmentTransaction ft = fm.beginTransaction();

fm 是这样的:

android.support.v4.app.FragmentManager fm = getFragmentManager();

我的 Fragment extends android.support.v4.app.Fragment,这些是我的导入:

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentTransaction;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

我从未见过我为 FragmentManager 获得了 null 有人有想法吗?

4

4 回答 4

83

将此替换为此getFragmentManager()getSupportFragmentManager()并确保您的活动扩展FragmentActivity

于 2013-02-18T10:59:52.267 回答
4

android.support.v4.app.Fragment来源:

// The fragment manager we are associated with.  Set as soon as the
// fragment is used in a transaction; cleared after it has been removed
// from all transactions.
FragmentManagerImpl mFragmentManager;

显然getFragmentManager()返回片段管理器的支持版本,但仅在事务期间(或父片段的子片段管理器)。

我将使用这个:

public FragmentManager getHostFragmentManager() {
    FragmentManager fm = getFragmentManager();
    if (fm == null && isAdded()) {
        fm = ((AppCompatActivity)getActivity()).getSupportFragmentManager();
    }
    return fm;
}
于 2015-09-24T18:44:37.470 回答
0

案例:当您需要从另一个片段(父片段)调用片段(子片段)时

始终使用getChildFragmentManager()而不是getFragmentManager()在您的父片段内。

于 2019-06-24T06:12:15.993 回答
-9

在清理和重建我的项目以及重新启动我的测试设备之后,这又以某种方式再次起作用。

于 2013-02-18T11:21:14.120 回答