Проблема с сбоем приложения Android 4.4 Hello Word для новичков — нажатие кнопки изменяет / обновляет TextView

#android #pointers #exception #null #android-4.4-kitkat

#Android #указатели #исключение #null #android-4.4-kitkat

Вопрос:

Новичок Android здесь. Пишу свое первое приложение hello world и не могу преодолеть две ошибки «К сожалению» и сбой. Я предполагаю, что это исключение нулевого указателя, но никакое количество поисковых запросов не помогает мне понять это лучше. Заранее большое вам спасибо.

AndroidManifest.xml

 <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.eventexample"
    android:versionCode="1"
    android:versionName="1.0" >
    <uses-sdk
        android:minSdkVersion="19"
        android:targetSdkVersion="19" />
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.example.eventexample.EventExampleActivity"
            android:label="@string/app_name" >

            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>        
        </activity>
    </application>
</manifest>
  

EventExampleActivity.java

 package com.example.eventexample;

import android.app.Activity;
import android.app.ActionBar;
import android.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.os.Build;
import android.widget.Button;
import android.widget.TextView;

public class EventExampleActivity extends Activity {
    @Override
    protected void onStart()
    {
        super.onStart();

        Button button = 
                (Button)findViewById(R.id.myButton);

            button.setOnClickListener(
                new Button.OnClickListener() {
                    public void onClick(View v) {
                        TextView myTextView = (TextView) findViewById(R.id.myTextView);
                        myTextView.setText("Button clicked");
                }
            }
        );
    }
}
  

activity_event_example.xml

 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@ id/myLayout"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    tools:context=".EventExampleActivity" >

    <Button
        android:id="@ id/myButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:text="@string/mybutton_string" />

    <TextView
        android:id="@ id/myTextView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@ id/myButton"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="41dp"
        android:text="@string/mytextview_string"
        android:textAppearance="?android:attr/textAppearanceLarge" />

</RelativeLayout>
  

Дамп консоли

 [2014-07-06 21:35:36 - EventExample] ------------------------------
[2014-07-06 21:35:36 - EventExample] Android Launch!
[2014-07-06 21:35:36 - EventExample] adb is running normally.
[2014-07-06 21:35:36 - EventExample] Performing com.example.eventexample.EventExampleActivity activity launch
[2014-07-06 21:35:38 - EventExample] Application already deployed. No need to reinstall.
[2014-07-06 21:35:38 - EventExample] Starting activity com.example.eventexample.EventExampleActivity on device 192.168.56.101:5555
[2014-07-06 21:35:38 - EventExample] ActivityManager: WARNING: linker: libdvm.so has text relocations. This is wasting memory and is a security risk. Please fix.
[2014-07-06 21:35:39 - EventExample] ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.example.eventexample/.EventExampleActivity }
  

Дамп LogCat

 07-07 02:35:38.276: E/AndroidRuntime(1681): FATAL EXCEPTION: main
07-07 02:35:38.276: E/AndroidRuntime(1681): Process: com.example.eventexample, PID: 1681
07-07 02:35:38.276: E/AndroidRuntime(1681): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.eventexample/com.example.eventexample.EventExampleActivity}: java.lang.NullPointerException
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.ActivityThread.access$800(ActivityThread.java:135)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.os.Handler.dispatchMessage(Handler.java:102)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.os.Looper.loop(Looper.java:136)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.ActivityThread.main(ActivityThread.java:5017)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at java.lang.reflect.Method.invokeNative(Native Method)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at java.lang.reflect.Method.invoke(Method.java:515)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at dalvik.system.NativeStart.main(Native Method)
07-07 02:35:38.276: E/AndroidRuntime(1681): Caused by: java.lang.NullPointerException
07-07 02:35:38.276: E/AndroidRuntime(1681):     at com.example.eventexample.EventExampleActivity.onStart(EventExampleActivity.java:25)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.Activity.performStart(Activity.java:5241)
07-07 02:35:38.276: E/AndroidRuntime(1681):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2168)
07-07 02:35:38.276: E/AndroidRuntime(1681):     ... 11 more
  

Комментарии:

1. Если вы создали действие с помощью мастера создания действий, у вас был бы setContentView() в onCreate(), а не OnStart(). setContentView() всегда устанавливается в onCreate() , а не в OnStart()

Ответ №1:

Попробуйте это —

 public class EventExampleActivity extends Activity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_event_example);
    Button button =(Button)findViewById(R.id.myButton);
    button.setOnClickListener(
            new Button.OnClickListener() {
                public void onClick(View v) {
                    TextView myTextView = (TextView) findViewById(R.id.myTextView);
                    myTextView.setText("Button clicked");
                }
            }
    );
}

}
  

В вашей деятельности вы должны переопределить метод onCreate и вызвать: setContentView(R.layout.activity_event_example) . Другие ответы частично верны, в обоих из них сказано, что вам нужно написать setContentView(R.id.activity_event_example); вместо этого вы должны написать setContentView(R.layout.activity_event_example);. Это должен быть R.layout.your_xml, потому что xml-файлы определены внутри класса layout, а не внутри класса id.

Если вы посмотрите внутрь R.java файл, после чего вы найдете что-то вроде

 public static final class layout {
    public static final int your_xml_name=0x7f030000;
   }
  

Поэтому измените id на layout .

Ответ №2:

Вы должны сообщить activity, какой XML должен отображаться для пользовательского интерфейса. Итак, в вашей активности переопределите метод onCreate и добавьте этот вызов: setContentView(R.id.activity_event_example)

Также переместите код, который у вас есть прямо сейчас в методе OnStart, в onCreate (он вызывается один раз, в то время как OnStart вызывается каждый раз, когда ваш экран выводится на передний план), но после вызова setContentView

Комментарии:

1. setContentView(R.id.activity_event_example); вывод строки с ошибкой «не может быть разрешен или не является полем». Спасибо.

2. @ArtemCherkes Это должно быть setContentView(R.layout.activity_event_example);

Ответ №3:

Как правило, код, который создает графический интерфейс, должен вводиться onCreate() , и вам нужно вызвать setContentView() перед findViewById()

Ваш класс должен выглядеть следующим образом:

 public class EventExampleActivity extends Activity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_event_example);
    Button button =(Button)findViewById(R.id.myButton);
    button.setOnClickListener(
            new Button.OnClickListener() {
                public void onClick(View v) {
                    TextView myTextView = (TextView) findViewById(R.id.myTextView);
                    myTextView.setText("Button clicked");
                }
            }
    );
}

}
  

Обновить:
Действительно, он не должен читать R.id . но R.layout.
Я отредактировал код, чтобы теперь он был правильным.

Комментарии:

1. Спасибо, он жалуется на то, что activity_event_example не может быть разрешен или не является полем. Предполагая, что это ссылка на файл макета?

2. Да, @ArtemCherkes, вы должны вызвать ссылку на ваш файл макета, пример: R.layout.file_name

3. Хм… посмотрите на ошибку, которую оно выдает. Есть ли в проекте другое место, на которое я должен ссылаться? i.imgur.com/buFUfXp.png

4. @ArtemCherkes пожалуйста, проверьте мой ответ. Этого не должно быть R.layout.your_xml R.id.your_xml .