Исключение Nullpointer в адаптере списка - PullRequest
0 голосов
/ 14 марта 2012

Я использую arrayadapter для отображения данных в виде списка. То, что я закодировал, показано ниже, но я получаю исключение нулевого указателя. Пожалуйста, скажите мне, что я пропустил?

ArrayAdapter<String> adapter;
setContentView(R.layout.menu_home_activity);
        OptionsList = (ListView) findViewById(R.id.OptionsLists);
String[] array = getResources().getStringArray(R.array.personal_settings);
            adapter = new ArrayAdapter<String>(MenuHomeActivity.this,
                    R.layout.menu_home_activity, R.id.text, array);
            OptionsList.setAdapter(adapter);

menu_home_activity.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <ListView
        android:name="@+id/OptionsLists"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content" >
    </ListView>

</LinearLayout>

Logcat говорит:

03-14 10:54:59.242: E/AndroidRuntime(267): Uncaught handler: thread main exiting due to uncaught exception
03-14 10:54:59.252: E/AndroidRuntime(267): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.biz.elife/com.biz.elife.MenuHomeActivity}: java.lang.NullPointerException
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2496)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.app.ActivityThread.access$2200(ActivityThread.java:119)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.os.Handler.dispatchMessage(Handler.java:99)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.os.Looper.loop(Looper.java:123)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.app.ActivityThread.main(ActivityThread.java:4363)
03-14 10:54:59.252: E/AndroidRuntime(267):  at java.lang.reflect.Method.invokeNative(Native Method)
03-14 10:54:59.252: E/AndroidRuntime(267):  at java.lang.reflect.Method.invoke(Method.java:521)
03-14 10:54:59.252: E/AndroidRuntime(267):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
03-14 10:54:59.252: E/AndroidRuntime(267):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
03-14 10:54:59.252: E/AndroidRuntime(267):  at dalvik.system.NativeStart.main(Native Method)
03-14 10:54:59.252: E/AndroidRuntime(267): Caused by: java.lang.NullPointerException
03-14 10:54:59.252: E/AndroidRuntime(267):  at com.biz.elife.MenuHomeActivity.onCreate(MenuHomeActivity.java:33)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-14 10:54:59.252: E/AndroidRuntime(267):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
03-14 10:54:59.252: E/AndroidRuntime(267):  ... 11 more

Редактировать:

33-я строка

OptionsList.setAdapter(adapter);

, когда я пытаюсь установить адаптерв списке выдается ошибка, если я удаляю эту строку, ошибка не отображается, а также компоненты не отображаются на экране, появляется только черный экран

Спасибо всем за драгоценное время и отвечает, что моя ошибка была в menu_home_activity, которую я добавил android:name="@+id/OptionsList" что я изменил на

android:id="@+id/OptionsList"

Ответы [ 5 ]

1 голос
/ 14 марта 2012

Просто замените это

      adapter = new ArrayAdapter<String>(MenuHomeActivity.this,
                R.layout.menu_home_activity, R.id.text, array);

в вашем коде

   adapter=new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,array);
1 голос
/ 14 марта 2012

Думаю, приведенный ниже код поможет вам решить вашу проблему:

public class ArrayAdapterDemo extends ListActivity {
   TextView selection;
   String[] items = { "this", "is", "a", "really", 
   "silly", "list" };
   @Override
   public void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
       setContentView(R.layout.main);
setListAdapter(new ArrayAdapter<String>(
      this,
      android.R.layout.simple_expandable_list_item_1,
      items));
selection=(TextView)findViewById(R.id.selection); 
   }
1 голос
/ 14 марта 2012

Попробуйте поместить код в блок try-catch Я думаю

OptionsList = (ListView) findViewById(R.id.OptionsLists);

вызывает нулевой указатель. Лучше обрабатывать код для возможных исключений (ноль или другие).

0 голосов
/ 14 марта 2012

Ваш список параметров не создается должным образом, что, вероятно, связано с проблемой XML-файла ure.ListView не раздувается должным образом;

попробуйте заменить match_parent на fill_parent в android: layout_width = "match_parent" и android: layout_height = "match_parent"

Надеюсь, это поможет.

0 голосов
/ 14 марта 2012

Проблема в 33-й строке вашего Java-файла для соответствующей активности. Я полагаю, ваш список не правильно инициализируется.

...