Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/402.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 回调中的class.this如何可以为null?_Java_Android_Android Fragments_Callback_Null - Fatal编程技术网

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

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

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

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()