我正在尝试编写一个程序,该程序将在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/