java - Android-Java 客户端-服务器 - AsyncTask 中的 Toast 崩溃应用程序

标签 java android android-asynctask client-server toast

我有 2 个应用程序通过 AsyncTask 进行通信。第一个应用程序是 Java 服务器,在我的 PC 上运行。第二个应用程序是 Android 客户端。

服务器向客户端发送如下消息:

" 1stMember , 2ndMember , 3rdMember , ... , 10thMember "

然后,客户端从客户端类的内部类connectTask中检索此消息。 但应用程序总是崩溃。

这是我的客户端MainActivity.java:

public class MainActivity extends FragmentActivity
{
    private TCPClient tcpclient;

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

        // Connect to server - See innerClass connectTask below
        new connectTask().execute("");
    }

    public class connectTask extends AsyncTask<String, String, TCPClient>
    {
        protected TCPClient doInBackground(String... message)
        {
            // Creation of TCPClient object...
            tcpclient=new TCPClient(new TCPClient.OnMessageReceived() 
            {
                public void messageReceived(String message) 
                {
                    publishProgress(message);
                    /*==> publishProgress receive message, then notify onProgressUpdate*/
                }
            });
            tcpclient.runClient();
            return null;
        }

        protected void onProgressUpdate(String...values)
        {
            super.onProgressUpdate(values);
            showMySelectedValues(values[0].toString());     
        }
    }

    public void showMySelectedValues(String values)
    {
        String[]selectedvalues=values.split(",");
        Log.i("LENGTH OF selectedvalues... : ",""+selectedvalues.length);
        Toast.makeText(getApplicationContext(),selectedvalues[3],Toast.LENGTH_SHORT).show();                        Toast.makeText(getApplicationContext(),selectedvalues[5],Toast.LENGTH_SHORT).show();

    }   
}

在崩溃之前,应用程序仍然向我显示 toast 。 这是我的 Logcat:

enter image description here

12-11 16:09:33.070: D/dalvikvm(11798): GC_FOR_ALLOC freed 5K, 12% free 9455K/10695K, paused 28ms, total 28ms
12-11 16:09:35.914: I/LENGTH OF selectedvalues... :(11798): 12
12-11 16:09:35.945: I/LENGTH OF selectedvalues... :(11798): 12
12-11 16:09:35.953: I/LENGTH OF selectedvalues... :(11798): 12
12-11 16:09:35.976: I/LENGTH OF selectedvalues... :(11798): 1
12-11 16:09:35.976: D/AndroidRuntime(11798): Shutting down VM
12-11 16:09:35.976: W/dalvikvm(11798): threadid=1: thread exiting with uncaught exception (group=0x4104f2a0)
12-11 16:09:35.984: E/AndroidRuntime(11798): FATAL EXCEPTION: main
12-11 16:09:35.984: E/AndroidRuntime(11798): java.lang.ArrayIndexOutOfBoundsException: length=1; index=3
12-11 16:09:35.984: E/AndroidRuntime(11798):    at com.fiamm.tcpandroid.MainActivity.showMySelectedValues(MainActivity.java:154)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at com.fiamm.tcpandroid.MainActivity$connectTask.onProgressUpdate(MainActivity.java:145)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at com.fiamm.tcpandroid.MainActivity$connectTask.onProgressUpdate(MainActivity.java:1)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:647)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at android.os.Handler.dispatchMessage(Handler.java:99)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at android.os.Looper.loop(Looper.java:137)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at android.app.ActivityThread.main(ActivityThread.java:4895)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at java.lang.reflect.Method.invokeNative(Native Method)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at java.lang.reflect.Method.invoke(Method.java:511)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:994)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761)
12-11 16:09:35.984: E/AndroidRuntime(11798):    at dalvik.system.NativeStart.main(Native Method)

这是调试器: enter image description here

当我在 onProgressUpdate(String...values) 中执行此操作时,它不会崩溃:

protected void onProgressUpdate(String...values)
{
    super.onProgressUpdate(values);
    Toast.makeText(getApplicationContext(),selectedvalues[3],Toast.LENGTH_SHORT).show();
}

但是当我制作超过 1 个 toast 时,应用程序会再次崩溃

我不明白我的代码有什么问题。有人可以帮我吗?

提前谢谢。

最诚挚的问候,

bean 腐

最佳答案

 java.lang.ArrayIndexOutOfBoundsException: length=1; index=3

长度为1。数组索引从0开始。

selectedvalues 的长度为 1。您正在尝试访问 selectedvalues[3]

关于java - Android-Java 客户端-服务器 - AsyncTask 中的 Toast 崩溃应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20521514/

相关文章:

java - 尝试提取对象的参数并将其传递给另一个类(不确定标题)

java - 终止永久运行的命令行 Java 应用程序的干净/推荐方法是什么?

android - 如何在 ConstraintLayout 中水平对齐两个 TextView 而不重叠?

java - 并行使用 ArrayList

Android - setSoTimeout 不工作

java - Javas 在 2011 年对 Winforms/WPF/Silverlight 的回答是什么

java - 如何在java中的结果集中添加列?

java - 安卓说话人识别

java - 在 Sqlite 中仅创建和更新单个值

android - 如何实现监听器