我在这里遇到一个很奇怪的问题。在我的fragment
中,经过我的inflate
layout
,findViewById()
方法有时会返回null。但这个问题根本不可重现。我收到Crashlytics的这些崩溃报告。而且这次事故也发生在QA的其中一位成员身上,但之后他也无法再现这个问题。findViewById()方法有时只返回null(大多数时间工作正常)
这里是我的片段代码
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View customView= inflater.inflate(R.layout.custom_view, container, false);
ImageView back= (ImageView) customView.findViewById(R.id.back);
//Throwing Null Pointer Exception for the below line.
back.someFunc();
return customView;
}
XML文件:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/topics_parent"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="?attr/default_background">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:layout_marginRight="@dimen/back_to_top_margin_right"
android:layout_marginBottom="@dimen/back_to_top_margin_bottom"
android:src="@drawable/back"
android:visibility="gone"
android:id="@+id/back"/>
<LinearLayout
android:id="@+id/error_parent"
android:layout_width="match_parent"
android:background="?attr/default_background"
android:orientation="vertical"
android:layout_height="match_parent">
</LinearLayout>
<ProgressBar
android:id="@+id/progressbar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"/>
</RelativeLayout>
崩溃日志
Fatal Exception: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.myapp/com.myapp.news.activities.NewsHomeActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ImageView.setOnClickListener(android.view.View$OnClickListener)' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2316)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2376)
at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:3928)
at android.app.ActivityThread.access$900(ActivityThread.java:147)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1287)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5253)
at java.lang.reflect.Method.invoke(Method.java)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
Caused by java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ImageView.setOnClickListener(android.view.View$OnClickListener)' on a null object reference
at com.myapp.news.fragments.TopicsGroupFragment.onCreateView(TopicsGroupFragment.java:157)
at android.app.Fragment.performCreateView(Fragment.java:2053)
at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:894)
at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1067)
at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1049)
at android.app.FragmentManagerImpl.dispatchActivityCreated(FragmentManager.java:1869)
at android.app.Activity.performCreateCommon(Activity.java:5970)
at android.app.Activity.performCreate(Activity.java:5977)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2269)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2376)
at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:3928)
at android.app.ActivityThread.access$900(ActivityThread.java:147)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1287)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5253)
at java.lang.reflect.Method.invoke(Method.java)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
有一个很艰难的时间弄清楚为什么findViewById()
将返回空值那种观点。
注:我有很多ImageView
resources
其ID是back
但他们都在不同的XML文件。
'查看customView = inflater.inflate(R.layout.custom_view,容器,FALSE); ImageView back =(ImageView)topicsView.findViewById(R.id.back);'?? 不应该是'(ImageView)customView.findViewById(R.id.back);'?? – SripadRaj
'topicsView'在哪里?如果从'onCreateView'方法返回'customView'方法,它应该是'customView'来访问布局视图 –
为什么当你在'customView'中膨胀布局时使用'topicsView'? –