AsyncTask 不断崩溃在 Android 模拟器上运行的演示应用程序

Posted

技术标签:

【中文标题】AsyncTask 不断崩溃在 Android 模拟器上运行的演示应用程序【英文标题】:AsyncTask keeps crashing demo app running on Android emulator 【发布时间】:2021-03-24 15:56:39 【问题描述】:

我目前正在通过阅读一本书来学习 android 应用程序开发,而我目前正在努力解决一些表面上看起来相当简单的问题。该界面由一个按钮和一个文本视图组成。该练习的目的是演示在执行耗时的任务时如何使用单独的线程。

我尝试过调试,onProgressUpdate 方法的values 数组确实包含传递给它的值,并且在尝试为myTextView 设置文本时似乎总是发生崩溃。如有任何帮助,我将不胜感激。

代码:

package com.ebookfrenzy.asyncdemo;

import androidx.appcompat.app.AppCompatActivity;
import android.os.AsyncTask;

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity 
    private TextView myTextView;
    private String tag = "Test";

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    

    public void buttonClick(View view) 
        AsyncTask task = new MyTask().execute();
    

    private class MyTask extends AsyncTask<String,Integer,String> 
        @Override
        protected void onPreExecute() 

        

        @Override
        protected void onProgressUpdate(Integer... values) 
            Log.i(tag,"publish: " + Integer.toString(values[0]));
            myTextView.setText("Counter = " + values[0]);
        

        @Override
        protected void onPostExecute(String result) 
            myTextView.setText(result);
        

        @Override
        protected String doInBackground(String... strings) 
            int i = 0;
            while (i <= 20) 
                Log.i(tag,"before publish: " + Integer.toString(i));
                publishProgress(i);
                try 
                    Thread.sleep(1000);
                    i++;
                 catch(Exception e) 

                
            

            return "Button Pressed";
        
    

Logcat 输出(由我添加的用于故障排除的 Log.i 项目创建)通常如下所示,但如果提示应用程序不断崩溃的警告消息弹出,“发布前”项目会不断填充 i 每次递增直到我关闭警告消息:

2020-12-13 23:17:04.499 31729-31772/com.ebookfrenzy.asyncdemo I/Test: before publish: 0
2020-12-13 23:17:04.503 31729-31729/com.ebookfrenzy.asyncdemo I/Test: publish: 0

Logcat 的错误部分:

    --------- beginning of crash
2020-12-13 23:19:47.635 353-353/com.ebookfrenzy.asyncdemo E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.ebookfrenzy.asyncdemo, PID: 353
    java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.TextView.setText(java.lang.CharSequence)' on a null object reference
        at com.ebookfrenzy.asyncdemo.MainActivity$MyTask.onProgressUpdate(MainActivity.java:34)
        at com.ebookfrenzy.asyncdemo.MainActivity$MyTask.onProgressUpdate(MainActivity.java:25)
        at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:715)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:193)
        at android.app.ActivityThread.main(ActivityThread.java:6669)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
2020-12-13 23:19:47.639 353-353/com.ebookfrenzy.asyncdemo I/Process: Sending signal. PID: 353 SIG: 9

【问题讨论】:

myTextViewnull,因为您永远不会为该字段分配值。请注意,AsyncTask 已被弃用,几年来它一直被认为是低于标准的解决方案。你可能想找一本更新的书。 谢谢,成功了。我错过了书中示例代码中的那一行。 《Android Studio 4.0 Development Essentials》一书于 2020 年 6 月出版,但这可能是一个盲点。或者它可能会在本章后面提到该类已过时。应该改用什么? 有趣。如果我正确阅读了目录,那本书在第 18 章中介绍了视图绑定,所以我很惊讶这个示例依赖于findViewById(),因为那本书直到第 65 章才涵盖AsyncTask。我会推荐使用协程AsyncTask (第 66 章),但你不是在 Kotlin 中编程,尽管那本书似乎涵盖了它。 ¯\_(ツ)_/¯ 视图绑定是在初次发布后添加的,因此作者建议其他示例尚未更新,但建议尝试一下。我在注销前刚刚完成了 AsyncTask 章节,所以我不知道接下来会发生什么,但是有针对 java 和 kotlin 的单独书籍,所以也许您正在查看 kotlin 版本的内容? "也许您正在查看 kotlin 版本的内容?" ——它有一大堆 Kotlin 章节,所以大概就是这样。我没有注意到他们每种语言都有不同的版本。而且我认为有一个有时令人困惑的书籍阵容...... :-) 【参考方案1】:

我认为myTextView 必须为空。

试试这个。

if (myTextView != null)
  myTextView.setText("Counter = " + values[0]);

你应该在onCreate()方法初始化myTextView

@Override
protected void onCreate(Bundle savedInstanceState) 
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    myTextView = (TextView) findViewById(R.id.mytextviewid); // put 

【讨论】:

谢谢,问题是我没有初始化myTextView 变量。

以上是关于AsyncTask 不断崩溃在 Android 模拟器上运行的演示应用程序的主要内容,如果未能解决你的问题,请参考以下文章

在 targetSdkVersion 8 上运行 AsyncTask 时 Android 崩溃

Android:初始化新 AsyncTask 时应用程序崩溃 (VerifyError)

通过在Android中实现Proguard,使用JDBC在Asynctask中崩溃

通过在 Android 中实现 Proguard 在使用 JDBC 的 Asynctask 中应用程序崩溃

Facebook 登录 AsyncTask #4 NullPointerException 启动时崩溃

AsyncTask 不断重复 onResume