我正在尝试编写一个程序,它将在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
答案 0 :(得分:1)
我猜您的EditText
不包含格式正确的数字。你能提供一些输入值的例子吗?
在此期间,请查看Integer.parseInt
:
public static void main(String args[]) throws Exception {
String valid = "925";
int parsed = Integer.parseInt(valid); // works
String invalid = "Hello World!";
int error = Integer.parseInt(invalid); // throws NumberFormatException
String empty = "";
int error2 = Integer.parseInt(empty); // throws NumberFormatException
}
答案 1 :(得分:1)
使用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。堆栈跟踪是查找意外异常原因的最重要信息之一。
答案 2 :(得分:-1)
试试这个:
timer1 = Integer.parseInt(et.getText()。toString());