我正在尝试编写一个程序,该程序将在EditText字段中输入数字并将其转换为整数,以便以后可以为应用程序设置计时器。这是我的代码。当我运行它时,它给我一个错误:“ Android java.lang.NumberFormatException:无效的int”。我的错误在哪里?提前致谢

import android.app.Activity;
import android.content.ComponentName;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

public class Start extends Activity  {
    Button button1;
    EditText et;
    String timer;
    int timer1;
    public void onCreate (Bundle savedInstanceState){
        super.onCreate(savedInstanceState);
        setContentView(R.layout.start);
        button1 = (Button)findViewById(R.id.button1);
        et = (EditText)findViewById(R.id.editText1);

        bull();


        button1.setOnClickListener ( new OnClickListener() {
    @Override
    public void onClick(View v) {
        // TODO Auto-generated method stub
        Intent startMain = new Intent(Intent.ACTION_MAIN);
        startMain.addCategory(Intent.CATEGORY_HOME);
        startMain.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        startActivity(startMain);
        int secondsDelayed = 1;
        new Handler().postDelayed(new Runnable() {
                public void run() {
                    Intent intent = new Intent(Start.this, MainActivity.class);

                    startActivity(intent);
                }
        }, secondsDelayed * timer1*1000);
    }
});
    }
    private void bull() {
        // TODO Auto-generated method stub
        timer1 = Integer.valueOf(et.getText().toString());
        }

}


这是我的LogCat:

03-16 01:39:10.663: I/Process(17577): Sending signal. PID: 17577 SIG: 9
03-16 01:39:10.853: D/AndroidRuntime(18166): Shutting down VM
03-16 01:39:10.853: W/dalvikvm(18166): threadid=1: thread exiting with uncaught exception (group=0x4104fac8)
03-16 01:39:10.863: E/AndroidRuntime(18166): FATAL EXCEPTION: main
03-16 01:39:10.863: E/AndroidRuntime(18166): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.scaryme/com.example.scaryme.Start}: java.lang.NumberFormatException: Invalid int: ""
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2247)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2297)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.ActivityThread.access$700(ActivityThread.java:152)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1282)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.os.Handler.dispatchMessage(Handler.java:99)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.os.Looper.loop(Looper.java:137)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.ActivityThread.main(ActivityThread.java:5328)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at java.lang.reflect.Method.invokeNative(Native Method)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at java.lang.reflect.Method.invoke(Method.java:511)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at dalvik.system.NativeStart.main(Native Method)
03-16 01:39:10.863: E/AndroidRuntime(18166): Caused by: java.lang.NumberFormatException: Invalid int: ""
03-16 01:39:10.863: E/AndroidRuntime(18166):    at java.lang.Integer.invalidInt(Integer.java:138)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at java.lang.Integer.parseInt(Integer.java:359)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at java.lang.Integer.parseInt(Integer.java:332)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at com.example.scaryme.Start.bull(Start.java:48)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at com.example.scaryme.Start.onCreate(Start.java:24)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.Activity.performCreate(Activity.java:5250)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097)
03-16 01:39:10.863: E/AndroidRuntime(18166):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
03-16 01:39:10.863: E/AndroidRuntime(18166):    ... 11 more

最佳答案

在您的onCreate()方法中,您可以:

public void onCreate (Bundle savedInstanceState) {
    ...
    et = (EditText)findViewById(R.id.editText1);
    bull()
    ...
}


EditText的初始内容是一个空字符串。但是,您立即调用bull(),它将执行以下操作:

timer1 = Integer.valueOf(et.getText().toString());


由于et包含一个空字符串(请记住,您已经从onCreate()调用了它,并且编辑框为空),所以Integer.valueOf()无法解析它,因为空字符串不是有效的整数。 Integer.valueOf()然后将引发您看到的异常。

您有几个直接选择:


不要从bull()呼叫onCreate(),或者
如果编辑文本为空,请使bull()不要尝试分析字符串。


我建议第一个,因为似乎不需要这样做(至少在您的示例中如此)。

在任何情况下,在正常操作期间,用户总是有可能意外输入无效的数字,因此,您将希望通过捕获异常并向用户显示有用的错误消息来优雅地处理该错误(例如,“请输入一个有效的整数!”)。

通常,当您遇到这样的异常时,您需要查看堆栈跟踪。堆栈跟踪清楚地显示了onCreate()-> bull()->异常代码路径,它还精确地标识了异常和调用发生在哪一行。一旦确定了异常的来源,通常可以帮助您查询引发该异常的方法的文档,该文档通常描述了引发异常的原因(然后知道原因,则可以解决问题)。例如,Integer.parseInt() documentation。堆栈跟踪是查找意外异常原因的最重要信息之一。

关于java - 字符串到整数。无效的int,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/22430490/

10-10 19:18