繁体   English   中英

回调中的class.this如何可以为null?

[英]How can class.this in a callback can be null?

我有一个片段。 在此片段中,我在json-rpc上运行一个http请求。 为了处理结果,我有我的回调是这样的。

FragmentClass.this.getActivity().runOnUiThread(new Runnable() {
    @Override
    public void run() {
        // Do something
    } 
});

问题是,有时我在第一行上收到NullPointerException ...我的初衷是,该片段被快速分离,可能是因为用户在请求运行时选择了另一个片段,所以

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)

谢谢您的帮助!

阿图尔

创建一个全局变量Context上下文;

比在Create方法上初始化变量:

上下文= get Activity();

而不是将其用作:

context. runOnUiThread (new Runnable() {
    @Override
    public void run() {
        // Do something
    } 
});

希望对您有帮助。

getActivity()onCreateonCreateView方法中返回null。
onViewCreated使用getActivity() 最好将getActivity与check- if (isAdded()) { }

在您的情况下,您会得到null,因为在您调用FragmentClass.this.getActivity()时,您的片段不再对用户可见,实际上已经调用了onStop。

为了进一步增加我的答案-
假设您正在执行AsyncTask的片段上调用方法doSomething()。 然后将YourFragmentClass.this作为方法参数传递给doSomething(YourFragmentClass thiz)并在doInBackground()onPostExecute()方法中使用此对象,而不要使用YourFragmentClass.this,因为YourFragmentClass.this返回null,因为在AsynTask运行时,您的片段将移至onPause或onStop。

好,

我改变了所有异步块

FragmentClass.this.getActivity()

getActivity()

这有助于提供帮助。 请不要问我为什么...我认为应该一样...

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM