Ошибка выполнения в textView.setText(сообщение) Почему? :-(

Я новичок в программировании для Android. Честно говоря, я искал ответы почти везде в Интернете. Пожалуйста помоги.

Вот типичная ссылка на stackoverflow и ближайшая к тому, чего я хочу достичь Change TextView text

Моя главная проблема в том. Всякий раз, когда я хочу изменить текст объекта TextView, я получаю ошибку времени выполнения, и приложение «принудительно закрывается». Имею опыт ООП на C++ и PHP. Я просто не понимаю, почему приложение завершается на textView.setText(message). Все определено. Я даже пробовал textView.setText("Hello"). всякий раз, когда я удаляю это утверждение, приложение запускается.

activity_main.xml (весь файл)

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/container"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="MyApp.MainActivity"
    tools:ignore="MergeRootFrame" />

фрагмент_main.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="MyApp.MainActivity$PlaceholderFragment" >

    <TextView
        android:id="@+id/hello_world"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />

</RelativeLayout>

MainActivity.java

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    String message = "hi there";
    TextView textView = (TextView) findViewById(R.id.hello_world);
    textView.setText("this is a test");

    if (savedInstanceState == null) {
        getSupportFragmentManager().beginTransaction()
                .add(R.id.container, new PlaceholderFragment()).commit();
    } // if
} // onCreate

// SKIPPED A FEW CODE

/**
 * 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);
        return rootView;
    } // onCreateView
} // PlaceholderFragment

ЛогКэт

06-23 20:11:42.106: W/dalvikvm(332): threadid=1: thread exiting with uncaught exception (group=0x40015560)
06-23 20:11:42.116: E/AndroidRuntime(332): FATAL EXCEPTION: main
06-23 20:11:42.116: E/AndroidRuntime(332): java.lang.RuntimeException: Unable to start activity ComponentInfo{MyApp/MyApp.MainActivity}: java.lang.NullPointerException
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.os.Handler.dispatchMessage(Handler.java:99)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.os.Looper.loop(Looper.java:123)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.app.ActivityThread.main(ActivityThread.java:3683)
06-23 20:11:42.116: E/AndroidRuntime(332):  at java.lang.reflect.Method.invokeNative(Native Method)
06-23 20:11:42.116: E/AndroidRuntime(332):  at java.lang.reflect.Method.invoke(Method.java:507)
06-23 20:11:42.116: E/AndroidRuntime(332):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
06-23 20:11:42.116: E/AndroidRuntime(332):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
06-23 20:11:42.116: E/AndroidRuntime(332):  at dalvik.system.NativeStart.main(Native Method)
06-23 20:11:42.116: E/AndroidRuntime(332): Caused by: java.lang.NullPointerException
06-23 20:11:42.116: E/AndroidRuntime(332):  at MyApp.MainActivity.onCreate(MainActivity.java:30)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
06-23 20:11:42.116: E/AndroidRuntime(332):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
06-23 20:11:42.116: E/AndroidRuntime(332):  ... 11 more
06-23 20:11:44.826: I/Process(332): Sending signal. PID: 332 SIG: 9

Что такое NullPointerException и неперехваченное исключение?

Опять же, приложение запускается, когда я удаляю строку setText(), байт завершается при включении. Что я делаю не так?


person sacre    schedule 22.06.2014    source источник
comment
Во-первых, прочитайте: stackoverflow.com/questions/23353173/ Затем отредактируйте свой вопрос, чтобы объяснить, что показывает ваша трассировка стека. Кроме того, объясните, где, по вашему мнению, вы используете приведенный здесь XML.   -  person CommonsWare    schedule 23.06.2014
comment
Привет. Спасибо за ссылку :-) Я добавил имена файлов xml и java и LogCat... Я также новичок в stackoverflow, я не знаком с макетом. Я думал, что ваш ответ был автоматическим ответом. Извините :-)   -  person sacre    schedule 23.06.2014
comment
Релевантно: stackoverflow.com/questions/23653778/   -  person laalto    schedule 23.06.2014


Ответы (1)


Вы звоните setContentView(R.layout.activity_main) в onCreate(). Вы не указали содержание res/layout/activity_main.xml в своем вопросе.

Однако ваша ошибка указывает на то, что res/layout/activity_main.xml не содержит виджет с android:id="@+id/hello_world".

В вашем файле res/layout/fragment_main.xml есть такой виджет, но вы пока не используете этот файл в коде, вставленном в ваш вопрос.

Либо:

  • Добавьте виджет с правильным идентификатором в res/layout/activity_main.xml или

  • Переместите свою логику TextView в подходящее место в зависимости от того, где вы пытаетесь использовать res/layout/fragment_main.xml.

person CommonsWare    schedule 23.06.2014
comment
спасибо за ответ! :-) Прошу прощения за отсутствие информации. Я учусь знать, что важно предоставить. Я избегаю таких длинных, длинных сообщений :-) в любом случае, я обновил файлы xml и не понимаю, куда поместить мой TextView в файле activity_main.xml, который является FrameLayout. Должен ли я добавить виджет с тем же @+id/hello_world, что и в fragment_main.xml? - person sacre; 23.06.2014
comment
@sacre: вам нужно решить, будет ли действие или фрагмент управлять этим TextView. Затем вы размещаете виджет в правильном макете на основе этого решения и помещаете свой код Java для TextView в правильный класс на основе этого решения. - person CommonsWare; 23.06.2014
comment
вы оба меня сбиваете с толку и имеете смысл... Вы предлагаете TextView перейти на FrameLayout, чтобы использовать MainActivity в java, ИЛИ переместить textView.setText(message) на PlaceholderFragment extends fragment { PlaceholderFragment () { onCreateView() { textView.SetText(...) }}} - person sacre; 23.06.2014
comment
Я не могу переместить свою логику в статический PlaceholderFragment, он жалуется :-( Какое подходящее место в MainActivity.java по умолчанию? Мне любопытна эта опция... Тем временем я попытаюсь переместить TextView в activity_main.xml - person sacre; 24.06.2014
comment
Спасибо!! :-D textView.setText("string") работает отлично, когда <TextView /> находится в <FrameLayout /> в activity_main.xml - person sacre; 24.06.2014