启动新活动时,Android空指针异常

时间:2012-11-26 01:55:03

标签: android

我正在为我的android类开发一个项目。我在MainActivity上列出了三个选项,当选择一个时,用户进入以下三种活动之一:a)输入新学生信息的活动,b)查看记录中所有学生的活动,或c)活动它允许跟踪目标学生的行为。 当我选择用于输入学生信息的单选按钮并单击“选择”按钮时,一切都按预期进行,即您将被发送到正确的活动。但是,当选择其他两个选项中的任何一个时,我会得到一个空指针异常。我在清单中宣布了所有三项活动。

这是我的班级代码:

    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>

我的stackTrace:

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中没有任何内容....

2 个答案:

答案 0 :(得分:3)

检查ActivityOnTaskBehaviour.java的第19行。您最有可能尝试在该行上的空对象上调用实例方法。

答案 1 :(得分:1)

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

您的问题位于ActivityOnTaskBehaviour.java第19行。