setText вызывает сбой приложения - PullRequest
0 голосов
/ 21 октября 2011

Я новичок в разработке Android.Я не могу понять, почему происходит сбой в эмуляторе. Когда я запускаю эту программу на своем эмуляторе Android, она открывается, а затем быстро закрывается, выдавая сообщение «К сожалению, привет, мир остановился.:

            <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
                android:layout_width="match_parent"
                android:layout_height="fill_parent"
                android:orientation="horizontal" >





                <TextView
                    android:id="@+id/textView1"
                    android:layout_width="match_parent"
                    android:layout_height="38dp"
                    android:editable="true"
                    android:text="TextView" />

            </LinearLayout>

LogCat:

            10-20 20:07:48.784: D/AndroidRuntime(601): Shutting down VM
            10-20 20:07:48.784: W/dalvikvm(601): threadid=1: thread exiting with uncaught exception (group=0x409951f8)
            10-20 20:07:48.804: E/AndroidRuntime(601): FATAL EXCEPTION: main
            10-20 20:07:48.804: E/AndroidRuntime(601): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.helloandroid/com.example.helloandroid.HelloAndroidActivity}: java.lang.NullPointerException
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1955)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.ActivityThread.access$600(ActivityThread.java:122)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.os.Handler.dispatchMessage(Handler.java:99)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.os.Looper.loop(Looper.java:137)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.ActivityThread.main(ActivityThread.java:4340)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at java.lang.reflect.Method.invokeNative(Native Method)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at java.lang.reflect.Method.invoke(Method.java:511)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at dalvik.system.NativeStart.main(Native Method)
            10-20 20:07:48.804: E/AndroidRuntime(601): Caused by: java.lang.NullPointerException
            10-20 20:07:48.804: E/AndroidRuntime(601):  at com.example.helloandroid.HelloAndroidActivity.onCreate(HelloAndroidActivity.java:16)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.Activity.performCreate(Activity.java:4465)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
            10-20 20:07:48.804: E/AndroidRuntime(601):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1919)
            10-20 20:07:48.804: E/AndroidRuntime(601):  ... 11 more
            10-20 20:12:48.894: I/Process(601): Sending signal. PID: 601 SIG: 9

Ответы [ 2 ]

2 голосов
/ 21 октября 2011

Если TextView не соответствует указанному вами коду, вы должны установить неправильный идентификатор макета. Ваш образец кода имеет setContentView(R.layout.main);. Возможно ли, что предоставленный вами xml-файл взят из файла, отличного от main.xml?

0 голосов
/ 21 июля 2015

Если вы разработали более одного файла макета для экрана другого размера, он должен иметь одинаковый идентификатор.если идентификатор не совпадает, это произойдет.

например

    public class HelloAndroidActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        TextView t=(TextView)findViewById(R.id.textView1);  
        t.setText("Secoknd text to display!"); 
        }   
    }

Layout / main.xml

<TextView
     android:id="@+id/textView1"
     android:layout_width="match_parent"
     android:layout_height="38dp"
     android:editable="true"
     android:text="TextView" />

Layout-large-hdpi / main.xml

<TextView
     android:id="@+id/textView2"
     android:layout_width="match_parent"
     android:layout_height="38dp"
     android:editable="true"
     android:text="TextView" />

Если вы работаете на мобильном телефоне ldpi, это работает.но если вы работаете на мобильном телефоне hdpi, он не может найти

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...