2012-11-26 77 views
-1

我正在爲我的android類工程。我在MainActivity上列出了三個選項,當選擇一個選項時,用戶進入以下三種活動之一:a)輸入新學生信息的活動,b)查看記錄中所有學生的活動,或c)活動它可以跟蹤目標學生的行爲。 當我選擇用於輸入學生信息的單選按鈕並單擊「選擇」按鈕時,所有內容都按需要發送,即您將被髮送到正確的活動。但是,當其他兩個選項中的任何一個被選中時,我都會得到一個空指針異常。我所有的三項活動都是在我的清單中宣佈的。當開始新的活動時,Android空指針異常

這裏是我的類代碼:

public void onButtonClicked (View v){ 
    RadioButton rdTrackBehaviour = (RadioButton)findViewById(R.id.radioOption2); 
    RadioButton rdEnterStudent = (RadioButton)findViewById(R.id.radioOption1); 
    RadioButton rdCurrentStudents = (RadioButton)findViewById(R.id.radioOption3); 

      if(rdEnterStudent.isChecked()){ 
       Intent enterIntent = new Intent(MainActivity.this, EnterStudentActivity.class); 
       startActivity(enterIntent); 
      } 
      if(rdTrackBehaviour.isChecked()){ 
       Intent onTaskIntent = new Intent(MainActivity.this, ActivityOnTaskBehaviour.class); 
       MainActivity.this.startActivity(onTaskIntent); 
      } 
      else{ 
       if(rdCurrentStudents.isChecked()){ 
        Intent currentStudentIntent = new Intent(MainActivity.this, StudentList.class); 
        startActivity(currentStudtenIntent); 
       } 
      } 
} 

而且從我的清單中的一個片段:

<application 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" 
    android:theme="@style/AppTheme" > 
    <activity 
     android:name=".MainActivity" 
     android:label="@string/title_activity_main" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 

      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 
    <activity 
     android:name=".EnterStudentActivity" 
     android:label="@string/title_activity_enter_student" > 
    </activity> 
    <activity 
     android:name=".ActivityOnTaskBehaviour" 
     android:label="@string/title_activity_activity_on_task_behaviour" > 
    </activity> 
    <activity 
     android:name=".StudentList" 
     android:label="@string/title_activity_student_list" > 
    </activity> 
    <activity 
     android:name=".Results" 
     android:label="@string/title_activity_results" > 
    </activity> 
</application> 

我的堆棧跟蹤:

11-25 19:47:39.735: E/AndroidRuntime(332): FATAL EXCEPTION: main 
11-25 19:47:39.735: E/AndroidRuntime(332): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.behaviourtracker/com.example.behaviourtracker.ActivityOnTaskBehaviour}: java.lang.NullPointerException 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.os.Handler.dispatchMessage(Handler.java:99) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.os.Looper.loop(Looper.java:123) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.app.ActivityThread.main(ActivityThread.java:3683) 
11-25 19:47:39.735: E/AndroidRuntime(332): at java.lang.reflect.Method.invokeNative(Native Method) 
11-25 19:47:39.735: E/AndroidRuntime(332): at java.lang.reflect.Method.invoke(Method.java:507) 
11-25 19:47:39.735: E/AndroidRuntime(332): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
11-25 19:47:39.735: E/AndroidRuntime(332): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
11-25 19:47:39.735: E/AndroidRuntime(332): at dalvik.system.NativeStart.main(Native Method) 
11-25 19:47:39.735: E/AndroidRuntime(332): Caused by: java.lang.NullPointerException 
11-25 19:47:39.735: E/AndroidRuntime(332): at com.example.behaviourtracker.ActivityOnTaskBehaviour.onCreate(ActivityOnTaskBehaviour.java:19) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
11-25 19:47:39.735: E/AndroidRuntime(332): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
11-25 19:47:39.735: E/AndroidRuntime(332): ... 11 more 

我是一個總的新秀,和完全難倒。在谷歌上一直在尋找一兩個小時,每個人似乎都一直在說,這與活動沒有在清單中註冊有關。我做錯了,還是有另一個問題? 另外,我扔了一個try catch塊左右

  if(rdTrackBehaviour.isChecked()){ 
       Intent onTaskIntent = new Intent(MainActivity.this, ActivityOnTaskBehaviour.class); 
       MainActivity.this.startActivity(onTaskIntent); 
      } 

隨着log.d,但沒有什麼在logcat中....

+3

你的問題在ActivityOnTaskBehaviour.java的第19行。 – kcoppock

+0

廢話......我從來沒有注意到......真是假!謝謝....(顯然我的意思是我是假人) – mrwienerdog

+0

請@kcoppock,把它放在一個答案,所以我可以選擇它。至少我可以做.... – mrwienerdog

回答

3

檢查第19行的ActivityOnTaskBehaviour.java。您很可能試圖在該行的空對象上調用實例方法。

1
11-25 19:47:39.735: E/AndroidRuntime(332): at com.example.behaviourtracker.ActivityOnTaskBehaviour.onCreate(ActivityOnTaskBehaviour.java:19) 

你的問題是,在第19行上ActivityOnTaskBehaviour.java 。