2

適切なキャスティングですか?ボタンを押した後、アプリは閉じています。2 行目 ( ) でコメントを切り替えると、正常にheight = Integer動作します。

public void onClick(View v) 
{
    EditText tHeight = (EditText)findViewById(R.id.tbHeight);
    height =  Integer.parseInt(tHeight.getText().toString());
}

このログを意味する場合は完全なログ:

02-09 14:41:58.941: I/dalvikvm(15417): Turning on JNI app bug workarounds for target SDK version 5...
02-09 14:42:03.918: D/AndroidRuntime(15417): Shutting down VM
02-09 14:42:03.918: W/dalvikvm(15417): threadid=1: thread exiting with uncaught exception (group=0x40bf11f8)
02-09 14:42:03.918: E/AndroidRuntime(15417): FATAL EXCEPTION: main
02-09 14:42:03.918: E/AndroidRuntime(15417): java.lang.NumberFormatException: Invalid int: ""
02-09 14:42:03.918: E/AndroidRuntime(15417):    at java.lang.Integer.invalidInt(Integer.java:138)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at java.lang.Integer.parseInt(Integer.java:359)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at java.lang.Integer.parseInt(Integer.java:332)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at com.example.as.MainActivity$1.onClick(MainActivity.java:64)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at android.view.View.performClick(View.java:3558)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at android.view.View$PerformClick.run(View.java:14157)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at android.os.Handler.handleCallback(Handler.java:605)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at android.os.Handler.dispatchMessage(Handler.java:92)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at android.os.Looper.loop(Looper.java:137)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at android.app.ActivityThread.main(ActivityThread.java:4514)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at java.lang.reflect.Method.invokeNative(Native Method)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at java.lang.reflect.Method.invoke(Method.java:511)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
02-09 14:42:03.918: E/AndroidRuntime(15417):    at dalvik.system.NativeStart.main(Native Method)
4

1 に答える 1

2

Integer.parseInt投げることができることを忘れないでくださいNumberFormatException。それがおそらく起こっていることです。

番号はありEditTextますか?スペースがある場合、それも解析されない可能性があります。tHeight.getText().toString().trim().replace(" ", "");スペースを削除するには、これを試してください。

また、XMLレイアウトでは、入力タイプを数値としてマークしてください。

そして最後になりましたが、try{ }catch(NumberFormatException e){ }クラッシュしないように必ずを入れてください

于 2013-02-09T13:38:31.057 に答える