【问题标题】:NullPointerException while calling AsyncTask.onPreExecute()调用 AsyncTask.onPreExecute() 时出现 NullPointerException
【发布时间】:2012-01-21 10:32:54
【问题描述】:

我是这个网站的新手。 我的AsyncTask 和我的 android 程序出错了……这是我编写的第一个异步任务。

名为 SocialApp.java 的主类

@Override
public void onCreate(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    TextView t = (TextView) this.findViewById(R.id.textView1);       

    HTMLParser task = new HTMLParser();
    task.setTextView(t);
    task.execute();        
}

一个基本的AsyncTask

public class HTMLParser extends AsyncTask<Void, Void, Boolean> {

    TextView t;
    String title = "error";

    public void setTextView(TextView t){
        this.t = t;
    }

    @Override
    protected void onPreExecute() {
        t.setText(title);
    }

    @Override
    protected Boolean doInBackground(Void ... arg0) {
        t.setText(title);
    }

    @Override
    protected void onPostExecute(Boolean result) {
        t.setText(title);
    }
}

导致这个

12-15 12:34:11.808: E/AndroidRuntime(590):  at cv.mk.android.utapp.HTMLParser.onPreExecute(HTMLParser.java:24)
12-15 12:34:11.808: E/AndroidRuntime(590):  at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:561)
12-15 12:34:11.808: E/AndroidRuntime(590):  at android.os.AsyncTask.execute(AsyncTask.java:511)
12-15 12:34:11.808: E/AndroidRuntime(590):  at cv.mk.android.utapp.SocialApp.onCreate(SocialApp.java:26)
12-15 12:34:11.808: E/AndroidRuntime(590):  at android.app.Activity.performCreate(Activity.java:4465)
12-15 12:34:11.808: E/AndroidRuntime(590):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
12-15 12:34:11.808: E/AndroidRuntime(590):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1919)
12-15 12:34:11.808: E/AndroidRuntime(590):  ... 11 more
12-15 12:34:19.666: D/dalvikvm(609): GC_FOR_ALLOC freed 33K, 3% free 9890K/10179K, paused 215ms
12-15 12:34:19.677: I/dalvikvm-heap(609): Grow heap (frag case) to 11.363MB for 1700016-byte allocation
12-15 12:34:19.747: D/dalvikvm(609): GC_CONCURRENT freed <1K, 3% free 11549K/11847K, paused 3ms+12ms
12-15 12:34:19.967: D/dalvikvm(609): GC_CONCURRENT freed 1K, 2% free 12079K/12231K, paused 2ms+3ms
12-15 12:34:20.037: D/dalvikvm(609): GC_FOR_ALLOC freed 1K, 2% free 12298K/12487K, paused 24ms
12-15 12:34:20.277: D/AndroidRuntime(609): Shutting down VM
12-15 12:34:20.277: W/dalvikvm(609): threadid=1: thread exiting with uncaught exception (group=0x409961f8)
12-15 12:34:20.277: D/dalvikvm(609): GC_CONCURRENT freed 1K, 1% free 13063K/13191K, paused 3ms+3ms
12-15 12:34:20.287: E/AndroidRuntime(609): FATAL EXCEPTION: main
12-15 12:34:20.287: E/AndroidRuntime(609): java.lang.RuntimeException: Unable to start activity ComponentInfo{cv.mk.android.utapp/cv.mk.android.utapp.SocialApp}: java.lang.NullPointerException
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1955)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.ActivityThread.access$600(ActivityThread.java:122)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.os.Handler.dispatchMessage(Handler.java:99)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.os.Looper.loop(Looper.java:137)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.ActivityThread.main(ActivityThread.java:4340)
12-15 12:34:20.287: E/AndroidRuntime(609):  at java.lang.reflect.Method.invokeNative(Native Method)
12-15 12:34:20.287: E/AndroidRuntime(609):  at java.lang.reflect.Method.invoke(Method.java:511)
12-15 12:34:20.287: E/AndroidRuntime(609):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
12-15 12:34:20.287: E/AndroidRuntime(609):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
12-15 12:34:20.287: E/AndroidRuntime(609):  at dalvik.system.NativeStart.main(Native Method)
12-15 12:34:20.287: E/AndroidRuntime(609): Caused by: java.lang.NullPointerException
12-15 12:34:20.287: E/AndroidRuntime(609):  at cv.mk.android.utapp.HTMLParser.onPreExecute(HTMLParser.java:24)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:561)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.os.AsyncTask.execute(AsyncTask.java:511)
12-15 12:34:20.287: E/AndroidRuntime(609):  at cv.mk.android.utapp.SocialApp.onCreate(SocialApp.java:26)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.Activity.performCreate(Activity.java:4465)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
12-15 12:34:20.287: E/AndroidRuntime(609):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1919)
12-15 12:34:20.287: E/AndroidRuntime(609):  ... 11 more

我已经尝试了一切,但我真的很困惑这里发生了什么......

感谢您的时间和精力。

【问题讨论】:

  • 而不是 t.setText(title); 在异步任务中,尝试在您的活动上创建一个方法来执行此操作,并在您的异步任务上调用该方法
  • 所以我必须将 SocialApp 的实例发送到 AsyncTask 中?
  • 你得到一个 NullPointerException,你确定 TextView 初始化正确吗?
  • 它出现在屏幕上...当我模拟它时
  • 不,您可以使用SocialApp.this 访问您的对象,例如SocialApp.this.findViewById(View v)

标签: android html-parsing android-asynctask


【解决方案1】:

您不能在 doInBackground 中调用 t.setText。该方法在不同的线程中运行,因此无法更新 UI。只有 UI 线程中的东西才能做到这一点。所以,在处理过程中如果要更新UI,必须调用publishProgress,然后UI线程会调用onProgressUpdate,在那里你可以更新UI。

请参阅此线程以获得很好的解释:

UpdateUI from AsyncTask

虽然这仍然有效,但我错过了 NullPointer 异常。 t 可能没有像上面所说的那样被初始化。

【讨论】:

  • 当我设置 textView 时,让我们在 super.onCreate(savedInstanceState); 之前说“你好”设置内容视图(R.layout.main);被称为......它工作正常:D......但 asynctask 把它搞砸了
  • 你能远程使用我的电脑看看有什么问题吗?
  • 谢谢你们...我收到错误...它没有正确初始化
【解决方案2】:

将 asynctask 放入 Activity 中,如下所示:

public class HTMLParser extends AsyncTask<Void, Void, Boolean> {

String title = "error";

public void setTextView(TextView t){
    ((TextView) SocialApp.this.findViewById(R.id.yourtextview)).setText(title);
}

@Override
protected void onPreExecute() {

    ((TextView) SocialApp.this.findViewById(R.id.yourtextview)).setText(title);

}

@Override
protected Boolean doInBackground(Void ... arg0) {
    ((TextView) SocialApp.this.findViewById(R.id.yourtextview)).setText(title);
}

@Override
protected void onPostExecute(Boolean result) {
    ((TextView) SocialApp.this.findViewById(R.id.yourtextview)).setText(title);


}
}

【讨论】:

  • @Noureddine....它说“SocialApp 类型的封闭实例在范围内是不可访问的”
  • 那么活动的名称不是SocialApp。将 SocialApp.this.findViewById 更改为 The_name_of_enclosure_activity.this.findViewById
  • @Nourreddine...它说公共类 SocialApp 扩展了 Activity {
  • 谢谢你们...我收到错误...它没有正确初始化
猜你喜欢
  • 2013-12-29
  • 2015-02-13
  • 2012-08-29
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-05-16
  • 1970-01-01
相关资源
最近更新 更多