Java 回调中的class.this如何可以为null?
我有一个碎片。在这个片段中,我在json rpc上运行了一个http请求。为了处理结果,我在回调中有类似的内容Java 回调中的class.this如何可以为null?,java,android,android-fragments,callback,null,Java,Android,Android Fragments,Callback,Null,我有一个碎片。在这个片段中,我在json rpc上运行了一个http请求。为了处理结果,我在回调中有类似的内容 FragmentClass.this.getActivity().runOnUiThread(new Runnable() { @Override public void run() { // Do something } }); 问题是,有时我在第一行得到一个NullPointerException。。。我的第一个意图是,片段分离为fast
FragmentClass.this.getActivity().runOnUiThread(new Runnable() {
@Override
public void run() {
// Do something
}
});
问题是,有时我在第一行得到一个NullPointerException。。。我的第一个意图是,片段分离为fast,可能是因为用户在请求运行时选择了另一个片段,因此
FragmentClass.this.getActivity();
没有活动,返回null。
我用这样一个if将整个东西括起来:
// New if:
if (FragmentClass.this.getActivity() != null) {
FragmentClass.this.getActivity().runOnUiThread(new Runnable() {
@Override
public void run() {
// Do something
}
});
}
但是。。。没有什么。。。现在我在if语句中得到一个NullPointerException。看来
FragmentClass.this
是空的
这怎么可能呢。我认为一个实例将被保留,直到没有代码部分需要它并且gc收集它
这是logcat给我的stacktrace。我已经更改了包名和类名。第192行是if语句的行
09-18 10:49:36.915 3860-3860/de.unkown.app E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.NullPointerException
at de.unkown.app.camera.#FragmentClass$6.onError(FragmentClass.java:192)
at de.unkown.app.webservice.JsonRpcService$10.onError(JsonRpcService.java:497)
at de.unkown.app.webservice.JsonRpcService$DefaultErrorListener.onErrorResponse(JsonRpcService.java:107)
at com.android.volley.Request.deliverError(Request.java:577)
at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:101)
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)
谢谢你的帮助
Artur创建一个全局变量上下文 然后在创建方法中初始化变量: 上下文=获取活动() 然后将其用作:
context. runOnUiThread (new Runnable() {
@Override
public void run() {
// Do something
}
});
希望这会对你有所帮助。好的
我在所有异步块中更改了
FragmentClass.this.getActivity()
到
这很有帮助。请不要问我为什么。。。我认为这应该是相同的…getActivity()
在onCreate
和onCreateView
方法中返回null。在创建的视图中使用
getActivity()
。使用getActivity在代码周围加上一个复选框-if(isAdded()){}
,这样做很好
在您的例子中,您将获得null,因为在调用FragmentClass.this.getActivity()时,您的片段对用户不再可见,实际上已经调用了onStop
进一步补充我的答案-假设您正在对执行
异步任务的片段调用doSomething()方法。然后将YourFragmentClass.this作为方法参数传递给doSomething(YourFragmentClass thiz)
,并在doInBackground()
和onPostExecute()
方法中使用此对象,而不是使用YourFragmentClass.this。这是因为YourFragmentClass.this返回null,因为在AsynTask运行时,您的片段可能已移动到暂停或停止状态。堆栈跟踪在哪里?请尝试getActivity()
而不是FragmentClass。这个.getActivity()
为什么不直接使用getActivity()?但不仅仅是getActivity()与FragmentClass一样。这个.getActivity()?我的意思是第一个运行作用域的方法,第二个说我要在哪个作用域中运行getActivity()。但我会尝试一下。在Java中,应该不可能观察到FragmentClass。这是空的。我不确定dalvik是否在这里做s.t.坏事。为了弄清楚您是否遇到了一些非常微妙的初始化错误,我们需要知道代码片段的确切上下文:是否可能在尚未完全初始化的对象上执行该片段?OuterClass.this被实现为一个合成的final字段,它被无形地指定为构造函数中的第一件事-超级构造函数和动态分派的巧妙组合可能会使该字段未初始化。首先,创建全局变量上下文是一个坏主意。它可能导致内存泄漏和运行时错误,尤其是当一个视图寻呼机中有多个片段时。其次,对于上下文,如果您使用的是AsyncTask,并且希望在AsyncTask的方法中使用上下文,请始终使用getContext()
,然后将上下文作为最终方法参数变量传递给包含AsyncTask的方法,并在AsyncTask的重写方法中使用。如果在AsyncTask的方法中使用getContext(),可能会导致NullPointerExceptioncontext.runOnUiThread甚至不会编译。它需要getActivity。所以下面的代码可以安全地使用if(isAdded())getActivity().runOnUiThread(newrunnable(){@Override public void run(){//Do something})代码>
getActivity()