Android Spinner вызывает сбой приложения, когда прокрутка достигает конца списка - PullRequest
0 голосов
/ 06 марта 2012

В одном из моих занятий я использовал Spinner .я заполняю его массивом SpinnerCountry объектов класса ... он определен следующим образом:

class SpinnerCounry {
    public SpinnerCounry(String spinnerText, String value) {
        this.spinnerText = spinnerText;
        this.value = value;
    }

    public String getSpinnerText() {
        return spinnerText;
    }

    public String getValue() {
        return value;
    }

    public String toString() {
        return spinnerText;
    }

    String spinnerText;
    String value;
}

Я связываю Spinner в функции, которая ниже:

private void setCountriesSpinner() {

    //create array of countries!
    final SpinnerCounry items[] = new SpinnerCounry[233];
    items[0] = new SpinnerCounry("Abkhazia", "207");
    items[1] = new SpinnerCounry("Afghanistan", "1");
    items[2] = new SpinnerCounry("Albania", "103");
    items[3] = new SpinnerCounry("Algeria", "2");
              ....
              ....
              ....
    items[230] = new SpinnerCounry("Zambia", "154");
    items[231] = new SpinnerCounry("Zimbabwe", "155");

    ArrayAdapter<SpinnerCounry> adapter = new ArrayAdapter<SpinnerCounry>(this, android.R.layout.simple_spinner_item, items);
         adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

    Spinner s = (Spinner) findViewById(R.id.spinner);

    s.setAdapter(adapter);      

    s.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
        public void onItemSelected(AdapterView<?> parent, View view,
                int position, long id) {

            //get the selected country's id to use later
            _countryId = items[position].getValue();

        }

        public void onNothingSelected(AdapterView<?> parent) {
        }
    });
}

Это работает хорошо ... загружает страны в счетчик и выбирает правильный идентификатор страны при нажатии / нажатии.

НО, когда я прокручиваю счетчик до последней страны, онвылетает приложение.Я посмотрел на LogCat, но не понял, в чем дело ...

LogCat выглядит следующим образом:

03-06 19:39:04.004: E/AndroidRuntime(1179): FATAL EXCEPTION: main
03-06 19:39:04.004: E/AndroidRuntime(1179): java.lang.NullPointerException
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.ArrayAdapter.createViewFromResource(ArrayAdapter.java:398)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.ArrayAdapter.getDropDownView(ArrayAdapter.java:419)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.Spinner$DropDownAdapter.getDropDownView(Spinner.java:543)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.Spinner$DropDownAdapter.getView(Spinner.java:539)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.AbsListView.obtainView(AbsListView.java:1949)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.ListPopupWindow$DropDownListView.obtainView(ListPopupWindow.java:1156)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.ListView.makeAndAddView(ListView.java:1756)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.ListView.fillDown(ListView.java:656)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.ListView.fillGap(ListView.java:620)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.AbsListView.trackMotionScroll(AbsListView.java:4408)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.widget.AbsListView$FlingRunnable.run(AbsListView.java:3687)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.os.Handler.handleCallback(Handler.java:587)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.os.Handler.dispatchMessage(Handler.java:92)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.os.Looper.loop(Looper.java:132)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at android.app.ActivityThread.main(ActivityThread.java:4025)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at java.lang.reflect.Method.invokeNative(Native Method)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at java.lang.reflect.Method.invoke(Method.java:491)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
03-06 19:39:04.004: E/AndroidRuntime(1179):     at dalvik.system.NativeStart.main(Native Method)

Любая помощь очень ценится.Спасибо

Ответы [ 2 ]

2 голосов
/ 06 марта 2012

Ваш массив содержит 233 записи.Но последняя запись [232] пуста, то есть null.Вот что делает ваше приложение аварийным.

Я бы рекомендовал использовать ArrayList вместо вашего текущего подхода с фиксированным массивом.

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

Вы создали массив из 233 элементов, но вставили только 232 из них.

Возможно, когда вы пытаетесь получить доступ к элементу по индексу 232, вы получаете исключение нулевого указателя.

...