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

您对下面的有关括约肌答案的评论与您的问题描述不符。 您在这里的问题中指出,当应用程序运行时,您会收到NumberFormatException。 如果不是这种情况,请在问题中提供对问题的实际,准确的描述。 还请包括所有堆栈跟踪或错误日志,并请在源代码片段中明确标记与您所看到的异常相对应的行,因为此处粘贴的代码不会显示行号。

感谢您更新问题。 我已经更新了答案。

在您的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()然后将引发您看到的异常。

您有几个直接选择:

不要从onCreate()调用bull(),或者

如果编辑文本为空,则使bull()不要尝试分析字符串。

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

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

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

非常感谢,这行得通。 而且我会牢记您的建议。 再次感谢

我猜您的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
}

感谢您的回复。 EditText的InputType设置为"数字"。 问题是该应用程序根本无法启动。 我的意思是,在我可以输入内容之前,它给出了错误。

@ user3365831那不是您在问题中的描述方式。

@ user3365831我添加了另一个带有空字符串的示例。 如果在您的应用程序启动时发生此错误,我假设您将一个空字符串传递给valueOf。 你能检查一下吗?

@JasonC对不起,如果它误导了您。 我是android的新手,有时我很难提出问题

尝试这个:

timer1 = Integer.parseInt(et.getText()。toString());

该死的..我会尽力找出来