如何在回调中将class.this设为null?

时间:2015-09-18 09:34:40

标签: java android android-fragments callback null

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

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

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

FragmentClass.this.getActivity();

没有活动并返回null。 我用这样的东西把整个事情都包括在内:

// 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给我的堆栈跟踪。我更改了包名和类名。第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)

感谢您的帮助!

阿图尔

3 个答案:

答案 0 :(得分:0)

创建全局变量Context context;

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

context = get Activity();

比使用它:

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

希望这对你有帮助。

答案 1 :(得分:0)

getActivity()onCreateonCreateView方法中返回null 在getActivity()内使用onViewCreated。最好使用带有检查的getActivity来包围代码 - if (isAdded()) { }

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

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

答案 2 :(得分:-1)

好的,

我改变了所有异步块

FragmentClass.this.getActivity()

getActivity()

这种接缝有所帮助。请不要问我为什么......我认为这应该是一样的......