Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/207.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android Java开发:应用程序停止工作_Java_Android_Xml_Error Handling_Listener - Fatal编程技术网

Android Java开发:应用程序停止工作

Android Java开发:应用程序停止工作,java,android,xml,error-handling,listener,Java,Android,Xml,Error Handling,Listener,我一直在为一个学校项目测试Android应用程序开发。我正在测试两个单选按钮,将改变一个文本字段。我想我得到的代码是正确的,但每当我试图运行它时,我都会得到一个“停止工作”。我使用的是API 11+ 这是我的XML文件: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+

我一直在为一个学校项目测试Android应用程序开发。我正在测试两个单选按钮,将改变一个文本字段。我想我得到的代码是正确的,但每当我试图运行它时,我都会得到一个“停止工作”。我使用的是API 11+

这是我的XML文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/RelativeLayout1"
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=".ServicesActivity" >

<RadioGroup
    android:id="@+id/radioGroupDepart"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerHorizontal="true"
    android:layout_centerVertical="true" >

 <RadioButton
    android:id="@+id/radioBtnMalta"
    android:layout_width="100dp"
    android:layout_height="wrap_content"
    android:layout_alignParentLeft="true"
    android:layout_below="@+id/textTest"
    android:layout_marginTop="26dp"
    android:text="Malta" />

<RadioButton
    android:id="@+id/radioBtnGozo"
    android:layout_width="100dp"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/radioBtnMalta"
    android:layout_alignBottom="@+id/radioBtnMalta"
    android:layout_alignParentRight="true"
    android:layout_marginRight="40dp"
    android:text="Gozo" />
</RadioGroup>



<TextView
    android:id="@+id/textTest"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true"
    android:layout_marginTop="23dp"
    android:text="Large Text"
    android:textAppearance="?android:attr/textAppearanceLarge" />
跳过导入,因为它们无法正确显示

public class ServicesActivity extends Activity implements RadioGroup.OnCheckedChangeListener {


//Radio Group Declaration and Edit Text
EditText et1;
RadioButton maltaRB;
RadioButton gozoRB;
RadioGroup gozoMaltaRBGroup;

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

    //Radio Group
    et1=(EditText)findViewById(R.id.textTest);
    maltaRB=(RadioButton)findViewById(R.id.MaltaRadioBtn);
    gozoRB=(RadioButton)findViewById(R.id.GozoRadioBtn);
    gozoMaltaRBGroup=(RadioGroup)findViewById(R.id.radioGroupDepart);
    gozoMaltaRBGroup.setOnCheckedChangeListener(this);
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.services, menu);

    return true;
}

TextView textTest = (TextView)findViewById(R.id.textTest);

@Override
public void onCheckedChanged(RadioGroup gozoMaltaRBGroup, int i) {
    if(i==maltaRB.getId()){

        textTest.setText("Leaving from Malta");
    }
    else if(i==gozoRB.getId()){
        textTest.setText("Leaving from Gozo");
    }

}
}

最后,这是我在LogCat上的错误日志:

  10-21 15:28:03.802: D/AndroidRuntime(829): Shutting down VM
10-21 15:28:03.802: W/dalvikvm(829): threadid=1: thread exiting with uncaught exception (group=0x414c4700)
10-21 15:28:03.821: E/AndroidRuntime(829): FATAL EXCEPTION: main
10-21 15:28:03.821: E/AndroidRuntime(829): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.services/com.example.services.ServicesActivity}: java.lang.NullPointerException
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2137)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.ActivityThread.access$600(ActivityThread.java:141)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.os.Handler.dispatchMessage(Handler.java:99)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.os.Looper.loop(Looper.java:137)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.ActivityThread.main(ActivityThread.java:5103)
10-21 15:28:03.821: E/AndroidRuntime(829):  at java.lang.reflect.Method.invokeNative(Native Method)
10-21 15:28:03.821: E/AndroidRuntime(829):  at java.lang.reflect.Method.invoke(Method.java:525)
10-21 15:28:03.821: E/AndroidRuntime(829):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
10-21 15:28:03.821: E/AndroidRuntime(829):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-21 15:28:03.821: E/AndroidRuntime(829):  at dalvik.system.NativeStart.main(Native Method)
10-21 15:28:03.821: E/AndroidRuntime(829): Caused by: java.lang.NullPointerException
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.Activity.findViewById(Activity.java:1853)
10-21 15:28:03.821: E/AndroidRuntime(829):  at com.example.services.ServicesActivity.<init>(ServicesActivity.java:42)
10-21 15:28:03.821: E/AndroidRuntime(829):  at java.lang.Class.newInstanceImpl(Native Method)
10-21 15:28:03.821: E/AndroidRuntime(829):  at java.lang.Class.newInstance(Class.java:1130)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
10-21 15:28:03.821: E/AndroidRuntime(829):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2128)
10-21 15:28:03.821: E/AndroidRuntime(829):  ... 11 more
10-21 15:28:03.802:D/AndroidRuntime(829):关闭虚拟机
10-21 15:28:03.802:W/dalvikvm(829):threadid=1:线程以未捕获异常退出(组=0x414c4700)
10-21 15:28:03.821:E/AndroidRuntime(829):致命异常:main
10-21 15:28:03.821:E/AndroidRuntime(829):java.lang.RuntimeException:无法实例化活动组件信息{com.example.services/com.example.services.ServicesActivity}:java.lang.NullPointerException
10-21 15:28:03.821:E/AndroidRuntime(829):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2137)
10-21 15:28:03.821:E/AndroidRuntime(829):位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
10-21 15:28:03.821:E/AndroidRuntime(829):在android.app.ActivityThread.access$600(ActivityThread.java:141)
10-21 15:28:03.821:E/AndroidRuntime(829):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
10-21 15:28:03.821:E/AndroidRuntime(829):在android.os.Handler.dispatchMessage(Handler.java:99)上
10-21 15:28:03.821:E/AndroidRuntime(829):在android.os.Looper.loop(Looper.java:137)
10-21 15:28:03.821:E/AndroidRuntime(829):位于android.app.ActivityThread.main(ActivityThread.java:5103)
10-21 15:28:03.821:E/AndroidRuntime(829):位于java.lang.reflect.Method.Invokenactive(本机方法)
10-21 15:28:03.821:E/AndroidRuntime(829):在java.lang.reflect.Method.invoke(Method.java:525)
10-21 15:28:03.821:E/AndroidRuntime(829):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
10-21 15:28:03.821:E/AndroidRuntime(829):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-21 15:28:03.821:E/AndroidRuntime(829):在dalvik.system.NativeStart.main(本机方法)
10-21 15:28:03.821:E/AndroidRuntime(829):由以下原因引起:java.lang.NullPointerException
10-21 15:28:03.821:E/AndroidRuntime(829):在android.app.Activity.findViewById(Activity.java:1853)
10-21 15:28:03.821:E/AndroidRuntime(829):位于com.example.services.ServicesActivity.(ServicesActivity.java:42)
10-21 15:28:03.821:E/AndroidRuntime(829):位于java.lang.Class.newInstanceImpl(本机方法)
10-21 15:28:03.821:E/AndroidRuntime(829):位于java.lang.Class.newInstance(Class.java:1130)
10-21 15:28:03.821:E/AndroidRuntime(829):在android.app.Instrumentation.newActivity(Instrumentation.java:1061)上
10-21 15:28:03.821:E/AndroidRuntime(829):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2128)
10-21 15:28:03.821:E/AndroidRuntime(829):。。。还有11个

任何帮助都将不胜感激

这些行正在返回
null

maltaRB=(RadioButton)findViewById(R.id.MaltaRadioBtn);
gozoRB=(RadioButton)findViewById(R.id.GozoRadioBtn);
TextView textTest = (TextView)findViewById(R.id.textTest);
检查
id
s。Java中的
id
s与
layout
文件中的不同

换成

maltaRB=(RadioButton)findViewById(R.id.radioBtnMalta);
gozoRB=(RadioButton)findViewById(R.id.radioBtnGozo);
这应该行得通。或者,您可以更改xml中的
id
s,但无论哪种方式,它们都必须匹配,或者您在尝试调用函数或设置侦听器时获得
NPE

此外,这将返回
null

maltaRB=(RadioButton)findViewById(R.id.MaltaRadioBtn);
gozoRB=(RadioButton)findViewById(R.id.GozoRadioBtn);
TextView textTest = (TextView)findViewById(R.id.textTest);

您需要在函数内部初始化它,否则它将返回
null
,因为它将在
setContentView()之前运行。只需声明并初始化它,就像你是你的另一个
视图一样。

你有额外的代码行:

TextView textTest = (TextView)findViewById(R.id.textTest);
在方法onCreateOptionsMenu()和onCheckedChanged()之间。这行不适合那里,它必须放在某个方法中。也许你可以把它分成两行:声明

TextView textTest;
和初始化

textTest = (TextView)findViewById(R.id.textTest);

但这取决于你真正想要什么。

谢谢你的帮助:)