NullPointerException在Eclipse Android Sdk中不幸的是myapp已经停止了

时间:2014-04-15 18:41:23

标签: android nullpointerexception emulation runtimeexception

我是初学者。坚持这个NullPointerException。这是一个简单的按钮程序。一旦我作为Android应用程序运行,项目就会打开并立即关闭,显示不幸的是我的应用程序已停止。

04-15 17:40:05.656: D/AndroidRuntime(599): Shutting down VM
04-15 17:40:05.656: W/dalvikvm(599): threadid=1: thread exiting with uncaught exception (group=0xb2adcd58)
04-15 17:40:05.666: E/AndroidRuntime(599): FATAL EXCEPTION: main
04-15 17:40:05.666: E/AndroidRuntime(599): Process: com.example.buttona, PID: 599
04-15 17:40:05.666: E/AndroidRuntime(599): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.buttona/com.example.buttona.Buttonwa}: java.lang.NullPointerException
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2208)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2270)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.ActivityThread.access$800(ActivityThread.java:138)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1209)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.os.Handler.dispatchMessage(Handler.java:102)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.os.Looper.loop(Looper.java:136)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.ActivityThread.main(ActivityThread.java:5042)
04-15 17:40:05.666: E/AndroidRuntime(599):  at java.lang.reflect.Method.invokeNative(Native Method)
04-15 17:40:05.666: E/AndroidRuntime(599):  at java.lang.reflect.Method.invoke(Method.java:515)
04-15 17:40:05.666: E/AndroidRuntime(599):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:776)
04-15 17:40:05.666: E/AndroidRuntime(599):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
04-15 17:40:05.666: E/AndroidRuntime(599):  at dalvik.system.NativeStart.main(Native Method)
04-15 17:40:05.666: E/AndroidRuntime(599): Caused by: java.lang.NullPointerException
04-15 17:40:05.666: E/AndroidRuntime(599):  at com.example.buttona.Buttonwa.onCreate(Buttonwa.java:29)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.Activity.performCreate(Activity.java:5231)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
04-15 17:40:05.666: E/AndroidRuntime(599):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2172)
04-15 17:40:05.666: E/AndroidRuntime(599):  ... 11 more
04-15 17:40:11.466: I/Process(599): Sending signal. PID: 599 SIG: 9
04-15 17:57:32.017: D/AndroidRuntime(662): Shutting down VM
04-15 17:57:32.017: W/dalvikvm(662): threadid=1: thread exiting with uncaught exception (group=0xb2adcd58)
04-15 17:57:32.027: E/AndroidRuntime(662): FATAL EXCEPTION: main
04-15 17:57:32.027: E/AndroidRuntime(662): Process: com.example.buttona, PID: 662
04-15 17:57:32.027: E/AndroidRuntime(662): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.buttona/com.example.buttona.Buttonwa}: java.lang.NullPointerException
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2208)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2270)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.ActivityThread.access$800(ActivityThread.java:138)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1209)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.os.Handler.dispatchMessage(Handler.java:102)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.os.Looper.loop(Looper.java:136)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.ActivityThread.main(ActivityThread.java:5042)
04-15 17:57:32.027: E/AndroidRuntime(662):  at java.lang.reflect.Method.invokeNative(Native Method)
04-15 17:57:32.027: E/AndroidRuntime(662):  at java.lang.reflect.Method.invoke(Method.java:515)
04-15 17:57:32.027: E/AndroidRuntime(662):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:776)
04-15 17:57:32.027: E/AndroidRuntime(662):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
04-15 17:57:32.027: E/AndroidRuntime(662):  at dalvik.system.NativeStart.main(Native Method)
04-15 17:57:32.027: E/AndroidRuntime(662): Caused by: java.lang.NullPointerException
04-15 17:57:32.027: E/AndroidRuntime(662):  at com.example.buttona.Buttonwa.onCreate(Buttonwa.java:29)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.Activity.performCreate(Activity.java:5231)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
04-15 17:57:32.027: E/AndroidRuntime(662):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2172)
04-15 17:57:32.027: E/AndroidRuntime(662):  ... 11 more
04-15 17:57:34.957: I/Process(662): Sending signal. PID: 662 SIG: 9

这是Java文件。

public class Buttonwa extends Activity {

Button name, surname;
TextView display;

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

    name = (Button) findViewById(R.id.name_button);
    surname = (Button) findViewById(R.id.surname_button);
    display = (TextView) findViewById(R.id.display);
    name.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub

            display.setText("Your Name Is Shashank Yadav");

        }
    });

    surname.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub

            display.setText("Your Name Is Yadav Shashank");

        }
    });

这是xml文件。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.buttona.Buttonwa$PlaceholderFragment" >

<TextView
    android:id="@+id/display"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="50dp"
     />
<Button 
android:id="@+id/name_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="10dp"
android:text="@string/Name"
/>

<Button 
android:id="@+id/surname_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_below="@+id/name_button"
android:text="@string/Surname"
/>


</RelativeLayout>

1 个答案:

答案 0 :(得分:2)

问题是你在片段fragment_main.xml中创建了View元素(我假设它被调用了,你还没有发布这个名字)但是你的代码期望它们在你的活动中。

执行此操作时:

setContentView(R.layout.activity_buttonwa);

name = (Button) findViewById(R.id.name_button);
surname = (Button) findViewById(R.id.surname_button);
display = (TextView) findViewById(R.id.display);

你说,&#34;嗨活动,查看activity_buttonwa.xml所有这些视图元素,你会在那里找到它们。

根据您的错误消息判断,namenull,因此当您尝试在其上设置NullPointerException时,您将获得OnClickListener。它是null,因为它不在您的activity_buttonwa.xml文件中。

要解决此问题,您可以 将所有xml移动到activity_buttonwa.xml ,您可以将通胀代码移动到您的片段中:

/**
 * A placeholder fragment containing a simple view.
 */
public static class PlaceholderFragment extends Fragment {

    public PlaceholderFragment() {
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View rootView = inflater.inflate(R.layout.fragment_main, container, false);

        name = (Button) rootView.findViewById(R.id.name_button);
        surname = (Button) rootView.findViewById(R.id.surname_button);
        display = (TextView) rootView.findViewById(R.id.display);

        // Add OnClickListeners, etc.

        return rootView;
    }
}

我会说将通胀代码移到你的片段会更好,如上所述。