Сбой EditText при пустом

#java #android #android-studio

#java #Android #android-studio

Вопрос:

итак, у меня есть поле EditText, и когда пользователь нажимает на число, начинается обратный отсчет. Проблема начинается, когда не вводится число, из-за сбоя приложения.

это то, что я пытался сделать:

Спасибо за помощь.


 public class MainActivity extends AppCompatActivity {

    EditText mEnterNumber;
    TextView mTest;
    int timerIsRunning = 0;

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

    public void StartRemainder(View view){
    
        mTest = findViewById(R.id.mTest);
        mEnterNumber = findViewById(R.id.mEnterNumber);
    
        int userNumb = Integer.parseInt(mEnterNumber.getText().toString()) * 60000;
    
    
        if(userNumb < 0 || mEnterNumber.toString().isEmpty()){
            Toast.makeText(MainActivity.this, "Please enter correct number", Toast.LENGTH_SHORT).show();
        }
        else{
    
        CountDownTimer userTimer = new CountDownTimer(userNumb,1000) {
    
            @Override
            public void onTick(long millisUntilFinished) {
    
                long millis = millisUntilFinished;
    
                //Convert milliseconds into hour,minute and seconds
                String hms = String.format("d:d:d",
                        TimeUnit.MILLISECONDS.toHours(millis),
                        TimeUnit.MILLISECONDS.toMinutes(millis) - TimeUnit.HOURS.toMinutes(TimeUnit.MILLISECONDS.toHours(millis)), TimeUnit.MILLISECONDS.toSeconds(millis) - TimeUnit.MINUTES.toSeconds(TimeUnit.MILLISECONDS.toMinutes(millis)));
                mTest.setVisibility(View.VISIBLE);
                mTest.setText(hms);
                timerIsRunning = 1;
    
            }
    
    
    
            @Override
            public void onFinish() {
    
    
            }
        }.start();
        }
    
    }
  

———————- Это ошибка, которую я получаю при сбое приложения:———————————

 2020-09-04 04:09:15.024 27096-27096/com.example.drinkme E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.drinkme, PID: 27096
java.lang.IllegalStateException: Could not execute method for android:onClick
    at androidx.appcompat.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:414)
    at android.view.View.performClick(View.java:6256)
    at android.view.View$PerformClick.run(View.java:24701)
    at android.os.Handler.handleCallback(Handler.java:789)
    at android.os.Handler.dispatchMessage(Handler.java:98)
    at android.os.Looper.loop(Looper.java:164)
    at android.app.ActivityThread.main(ActivityThread.java:6541)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
 Caused by: java.lang.reflect.InvocationTargetException
    at java.lang.reflect.Method.invoke(Native Method)
    at androidx.appcompat.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:409)
    at android.view.View.performClick(View.java:6256) 
    at android.view.View$PerformClick.run(View.java:24701) 
    at android.os.Handler.handleCallback(Handler.java:789) 
    at android.os.Handler.dispatchMessage(Handler.java:98) 
    at android.os.Looper.loop(Looper.java:164) 
    at android.app.ActivityThread.main(ActivityThread.java:6541) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 
 Caused by: java.lang.NumberFormatException: For input string: ""
    at java.lang.Integer.parseInt(Integer.java:620)
    at java.lang.Integer.parseInt(Integer.java:643)
    at com.example.drinkme.MainActivity.StartRemainder(MainActivity.java:40)
    at java.lang.reflect.Method.invoke(Native Method) 
    at androidx.appcompat.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:409) 
    at android.view.View.performClick(View.java:6256) 
    at android.view.View$PerformClick.run(View.java:24701) 
    at android.os.Handler.handleCallback(Handler.java:789) 
    at android.os.Handler.dispatchMessage(Handler.java:98) 
    at android.os.Looper.loop(Looper.java:164) 
    at android.app.ActivityThread.main(ActivityThread.java:6541) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
  

 

строка ошибки:

 int userNumb = Integer.parseInt(mEnterNumber.getText().toString()) * 60000;
  

Комментарии:

1. Привет, Дор, могу я увидеть полную трассировку стека?

2. @FelixFavourChinemerem спасибо за воспроизведение, вы имеете в виду полный код?

3. Нет, я имею в виду фрагмент кода, который показывает вам, что пошло не так с вашим кодом. Обычно это видно на вкладке Run или Debug вашей Android Studio ниже.

4. Конечно, я редактирую свой пост.

5. попробуйте включить блок try-catch для исключения: NumberFormatException для этой строки, int userNumb = Integer.parseInt(mEnterNumber.getText().toString()) * 60000;

Ответ №1:

Я предполагаю, что проблема в этой строке:

 int userNumb = Integer.parseInt(mEnterNumber.getText().toString()) * 60000;
  

И это потому, что пустая строка ( "" ) не может быть преобразована в число, в отличие от таких строк, как "1" или "2"

Чтобы исправить это: мы предоставляем блок try-catch для NumberFormatException

 int userNumb = 0;
try {
    if (mEnterNumber != null amp;amp; !TextUtils.isEmpty(mEnterNumber.getText().toString())) {
        userNumb = Integer.parseInt(mEnterNumber.getText().toString()) * 60000; 
    }
} 
catch (NumberFormatException ex) {}
  

Ответ №2:

Вы не получаете текст из edittext, прежде чем проверять, пуст он или нет. Попробуйте это :

 if(userNumb < 0 amp;amp; mEnterNumber.`getText()`.toString().isEmpty()){
    Toast.makeText(MainActivity.this, "Please enter correct number", 
    Toast.LENGTH_SHORT).show();
    int userNumb = Integer.parseInt(mEnterNumber.getText().toString()) * 60000;
}
  

Как вы можете видеть, я поместил преобразование целых чисел в блок if, поскольку это также может быть причиной этого.

Комментарии:

1. Теперь я понял, спасибо 🙂

Ответ №3:

Как сказал Феликс Фавор, это потому, что вы пытаетесь разобрать нечисловой элемент в строку. Эта строка:

 mEnterNumber = findViewById(R.id.mEnterNumber);
  

Скорее всего, значение будет равно нулю, если ничего не введено. Вы можете попробовать установить для него числовое значение:

     mEnterNumber = findViewById(R.id.mEnterNumber);
    if mEnterNumber.getText().toString().equals("")
    {
        int userNumb = 0;  // or whatever value you want to set as a starting default
    }
    else
    {
        int userNumb = Integer.parseInt(mEnterNumber.getText().toString()) * 60000;
    }
  

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

Кроме того, вы также можете установить его в XML следующим образом:

     <EditText
    android:id="@ id/mEnterNumber"
    ...
    android:text="0" />
  

Ответ №4:

Я использую что-то вроде этого —

 if (mEnterNumber.getText().toString().matches("")){
            Toast.makeText(this, "Please Enter any number", Toast.LENGTH_SHORT).show();
            return;
        }
  

Я надеюсь, что это предотвратит сбой.