2つのEditTextフィールドからテキストを取得しようとしています。これを整数値に変換し、それに基づいてさらにコードを実行します。これが私のコードが私のonCreateメソッドからこれまでのところ何であるかです
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button go = (Button)findViewById(R.id.button1);
go.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
EditText timer = (EditText)findByViewId(R.id.editText2);
EditText beeps = (EditText)findByViewId(R.id.editText1);
try{
int length = Integer.valueOf(timer.getText().toString());
int beepRepeat = Integer.valueOf(beeps.getText().toString());
Log.d("onClick","starting alarm");
initializeAlarm(length, beepRepeat);//(length, beepRepeat);
}
catch (Exception numberFormatException){
Log.d("Catch","Caught number format exception");
//Log.d("Catch",timer.getText().toString());
//Log.d("Catch",beeps.getText().toString());
initializeAlarm(2,3);
};
}
});
}
ただし、Log.d( "Catch"、timer.getText()。toString());でエラーがスローされます。いったいなぜ私はそこでエラーが発生するのでしょうか。私がしているのは、テキストを文字列として印刷することだけです。これがエラーjava.lang.nullPointerExceptionであり、キャッチされない例外でスレッドが終了します(group = 0x40015560)
getText()がnullPointerExceptionをスローする理由を誰かが知っていますか?
編集:これが私のactivity_main.xmlです
<EditText
android:id="@+id/editText1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/editText2"
android:layout_below="@+id/textView2"
android:ems="10"
android:inputType="number" />
<EditText
android:id="@+id/editText2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/editText1"
android:layout_centerHorizontal="true"
android:layout_marginTop="46dp"
android:ems="10"
android:inputType="number|numberDecimal" >
</EditText>
編集:これはnumberFormatExceptionエラーからの情報です
01-21 00:08:53.789: W/System.err(325): java.lang.NullPointerException
01-21 00:08:53.800: W/System.err(325): at com.example.americancheesecakesupreme5000.MainActivity$1.onClick(MainActivity.java:31)
01-21 00:08:53.800: W/System.err(325): at android.view.View.performClick(View.java:2485)
01-21 00:08:53.811: W/System.err(325): at android.view.View$PerformClick.run(View.java:9080)
01-21 00:08:53.811: W/System.err(325): at android.os.Handler.handleCallback(Handler.java:587)
01-21 00:08:53.820: W/System.err(325): at android.os.Handler.dispatchMessage(Handler.java:92)
01-21 00:08:53.820: W/System.err(325): at android.os.Looper.loop(Looper.java:123)
01-21 00:08:53.830: W/System.err(325): at android.app.ActivityThread.main(ActivityThread.java:3683)
01-21 00:08:53.830: W/System.err(325): at java.lang.reflect.Method.invokeNative(Native Method)
01-21 00:08:53.830: W/System.err(325): at java.lang.reflect.Method.invoke(Method.java:507)
01-21 00:08:53.840: W/System.err(325): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
01-21 00:08:53.840: W/System.err(325): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
01-21 00:08:53.840: W/System.err(325): at dalvik.system.NativeStart.main(Native Method)
編集:私の問題は、何らかの理由でコンパイルされて正常に実行されたと思われるFindViewByIDではなくFindByViewIdを呼び出すことによってEditTextによって宣言されたことでした...