2012-10-14 77 views
1

整数值,当我尝试运行,下面的代码,我的程序有停止。我想要这个代码从edittext得到值,但它不像我预期的那样工作。我究竟做错了什么?获取从EditText上

public class MainActivity extends Activity { 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    Button sum = (Button) findViewById(R.id.button1); 
    Button cancel = (Button) findViewById(R.id.button2); 

    final EditText from = (EditText) findViewById(R.id.editText1); 
    final EditText upto = (EditText) findViewById(R.id.editText2); 
    final EditText runsum = (EditText) findViewById(R.id.editText3); 

    final int f = Integer.parseInt(from.getText().toString()); 
    final int u = Integer.parseInt(upto.getText().toString()); 

} 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     getMenuInflater().inflate(R.menu.activity_main, menu); 
     return true; 
    } 
} 

这里是我的logcat抱歉混乱:/

08-28 19:34:44.241: E/Trace(3346): error opening trace file: No such file or directory (2) 
08-28 19:34:44.780: D/AndroidRuntime(3346): Shutting down VM 
08-28 19:34:44.780: W/dalvikvm(3346): threadid=1: thread exiting with uncaught exception(group=0x40a13300) 
08-28 19:34:44.790: E/AndroidRuntime(3346): FATAL EXCEPTION: main 
08-28 19:34:44.790: E/AndroidRuntime(3346): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.project/com.example.project.MainActivity}: java.lang.NumberFormatException: Invalid int: "" 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2059) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.ActivityThread.access$600(ActivityThread.java:130) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.os.Handler.dispatchMessage(Handler.java:99) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.os.Looper.loop(Looper.java:137) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.ActivityThread.main(ActivityThread.java:4745) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at java.lang.reflect.Method.invokeNative(Native Method) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at java.lang.reflect.Method.invoke(Method.java:511) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at dalvik.system.NativeStart.main(Native Method) 
08-28 19:34:44.790: E/AndroidRuntime(3346): Caused by: java.lang.NumberFormatException: Invalid int: "" 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at java.lang.Integer.invalidInt(Integer.java:138) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at java.lang.Integer.parseInt(Integer.java:359) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at java.lang.Integer.parseInt(Integer.java:332) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at com.example.project.MainActivity.onCreate(MainActivity.java:25) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.Activity.performCreate(Activity.java:5008) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023) 
08-28 19:34:44.790: E/AndroidRuntime(3346):  ... 11 more 
08-28 19:35:10.560: E/Trace(3394): error opening trace file: No such file or directory (2) 
08-28 19:35:11.629: D/gralloc_goldfish(3394): Emulator without GPU emulation detected. 
08-28 19:48:19.295: I/Choreographer(3394): Skipped 41 frames! The application may be doing too much work on its main thread. 
+2

是它抛出一个错误,这是什么意思:“我不能让它”?如果你有错误,你应该发布你的logcat – MikeIsrael

+0

你想从哪里获得editText? R是什么样的对象?它会覆盖很多其他代码或至少缺少一些补充。 –

回答

3

这个问题似乎是,当活动被bringed到前面有在EditText没有价值。整数解析器不知道如何解析空字符串,所以抛出异常。

您需要检查在EditText现有文本的解析

final int f = -1; // or other invalid value 
if (from.getText().toString().length() > 0) 
    f = Integer.parseInt(from.getText().toString()); 

同样,对于其他EditText

+0

这可能会有所帮助。我现在正在尝试感谢所有的帮助。 – theduman

1

之前,你可以从你的logcat的看到:

08-28 19 :34:44.790:E/AndroidRuntime(3346):引起:java.lang.NumberFormatException:无效int:“”

有一个空输入,无法转换为int

尝试验证用户输入。

1

-请检查EditText值,是一个有效的integer值或不

试试这个代码:

int i = 0; 

try{ 

    i = Integer.parseInt(from.getText().toString()); 

}catch(NumberFormatException ex){ 

    System.out.println("Value at TextView is not a valid integer"); 

} 
+0

如果'EditText'没有长度限制或类似的东西,这是正确的方法。其他解决方案通常会引发异常并使应用程序崩溃。 – Gimali