приложение Android упало при загрузке нового намерения - PullRequest
0 голосов
/ 23 марта 2019

Я делаю приложение для Android, где вы можете практиковать умножение. Вы выбираете число от 1 до 10, а затем вы получите 10 вопросов. после этого вы будете перенаправлены обратно в меню. но после этого, если вы выполните еще один набор из 10 вопросов, приложение будет зависать после последнего вопроса.

package com.example.rick2.rekentuin_native;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;

public class OefenenActivity extends AppCompatActivity {

int index = 0;
int intArray[] = new int[]{1,2,3,4,5,6,7,8,9,10};
TextView tv2;
String sessionId;

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

    sessionId = getIntent().getStringExtra("EXTRA_SESSION_ID");
    TextView tv1 = findViewById(R.id.textView6);
    tv1.setText(sessionId);



    tv2 = findViewById(R.id.textView5);
    tv2.setText(Integer.toString(intArray[index]));
}

public void CheckAns(View view) {
    EditText edit = findViewById(R.id.editText4);
    Integer result = Integer.parseInt(edit.getText().toString());
    int number1 = Integer.parseInt(sessionId);

    if (result == intArray[index] * number1) {
        if (index < 10) {
            index++;
            tv2.setText(Integer.toString(intArray[index]));
            edit.setText("");
        }
        else{
            Intent intent2 = new Intent(this, MenuOefenActivity.class);
            startActivity(intent2);
        }
    }
    else{
        edit.setText("");
    }
}

}

logcat выдаёт мне эту ошибку, но я не могу найти ни одного клика, который не работает.

2019-03-23 13:49:44.066 24510-24510/com.example.rick2.rekentuin_native E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.rick2.rekentuin_native, PID: 24510
java.lang.IllegalStateException: Could not execute method for android:onClick
    at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:390)
    at android.view.View.performClick(View.java:6597)
    at android.view.View.performClickInternal(View.java:6574)
    at android.view.View.access$3100(View.java:778)
    at android.view.View$PerformClick.run(View.java:25885)
    at android.os.Handler.handleCallback(Handler.java:873)
    at android.os.Handler.dispatchMessage(Handler.java:99)
    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)
 Caused by: java.lang.reflect.InvocationTargetException
    at java.lang.reflect.Method.invoke(Native Method)
    at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:385)
    at android.view.View.performClick(View.java:6597) 
    at android.view.View.performClickInternal(View.java:6574) 
    at android.view.View.access$3100(View.java:778) 
    at android.view.View$PerformClick.run(View.java:25885) 
    at android.os.Handler.handleCallback(Handler.java:873) 
    at android.os.Handler.dispatchMessage(Handler.java:99) 
    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) 
 Caused by: java.lang.ArrayIndexOutOfBoundsException: length=10; index=10
    at com.example.rick2.rekentuin_native.OefenenActivity.CheckAns(OefenenActivity.java:40)
    at java.lang.reflect.Method.invoke(Native Method) 
    at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:385) 
    at android.view.View.performClick(View.java:6597) 
    at android.view.View.performClickInternal(View.java:6574) 
    at android.view.View.access$3100(View.java:778) 
    at android.view.View$PerformClick.run(View.java:25885) 
    at android.os.Handler.handleCallback(Handler.java:873) 
    at android.os.Handler.dispatchMessage(Handler.java:99) 
    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) 

Ответы [ 2 ]

1 голос
/ 23 марта 2019

Ошибка в строке # 40 вашей активности: tv2.setText(Integer.toString(intArray[index]));

Причина в том, что вы увеличиваете индекс элемента для извлечения до получения запрашивающего массива.Итак, у вас есть два варианта:

a) инициализировать поле index с помощью -1

ИЛИ

b) изменить порядок строк:

  tv2.setText(Integer.toString(intArray[index]));
  index++;

вместо

  index++;
  tv2.setText(Integer.toString(intArray[index]));
0 голосов
/ 23 марта 2019

ваш код:

Intent intent2 = new Intent(this, MenuOefenActivity.class);

попробуйте это:

Intent intent2 = new Intent(OefenenActivity.this, MenuOefenActivity.class);

Я надеюсь, что это может помочь: -)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...