#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;
}
Я надеюсь, что это предотвратит сбой.