notifyDataSetChanged() вызывает исключение IndexOutOfBoundsException

Вот сокращенная версия моего кода.

public class MainActivity extends ActionBarActivity {

private ArrayList<String> entry = new ArrayList<String>();
private String[] entryString = new String[11];
private ArrayAdapter<String> aa;
private ListView entryListView;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    entryListView = (ListView) findViewById(R.id.listView1);
    int listID = R.layout.entry_layout;
    aa = new EntryAdapter(this, listID, entry);
    entryListView.setAdapter(aa);
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
    switch (id) {
    case R.id.action_add: {
        Intent intent = new Intent(MainActivity.this, AddActivity.class);
        startActivityForResult(intent, 1);
        break;
    }
    }
    return super.onOptionsItemSelected(item);
}

@Override
public void onActivityResult(int rc, int resc, Intent i) {
    super.onActivityResult(rc, resc, i);
    entryString = i.getStringArrayExtra("Entry");
    this.onNewItemAdded(entryString);
}

public void onNewItemAdded(String[] _entry){
    String key = new String();
    key = _entry[0];
    entry.add(key);
    aa.notifyDataSetChanged();   //Runs without crashing when this is removed.
}

Класс адаптера,

@SuppressLint("Instantiatable")
public class EntryAdapter extends ArrayAdapter<String>{

private ArrayList<String> entries;
int count;
int resource;
public EntryAdapter(Context _context, int _resource, List<String> _entries){
    //TODO Auto-generated constructor stub
    super(_context, _resource, R.id.key, _entries);
    this.resource = _resource;
    this.entries = new ArrayList<String>(_entries);
    this.count = 0;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    View row = convertView;

    if (convertView == null) {
        String inflater = Context.LAYOUT_INFLATER_SERVICE;
        LayoutInflater li;
        li = (LayoutInflater) getContext().getSystemService(inflater);
        row = li.inflate(resource, parent, false);
    }

    TextView keyView = (TextView) row.findViewById(R.id.key);
    TextView siteView = (TextView) row.findViewById(R.id.site);

    for(int c=0; c<11; c++){
        while(!entries.get(c).toString().equals("")){
            count++;
        }
    }

    keyView.setText(entries.get(position));
    siteView.setText(count + "sources");

    return row;
}
} 

Комментируя вызов aa.notifyDataSetChanged() в MainActivity, приложение работает без сбоев, но выдает

IndexOutOfBoundsException: недопустимый индекс 0, размер равен 0

когда это не комментируется.

PS: XML отлично подходит.

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

Вот журнал

Если вы создаете новый ArrayList, вызывая

public class MainActivity extends ActionBarActivity {

private ArrayList<String> entry = new ArrayList<String>();
private String[] entryString = new String[11];
private ArrayAdapter<String> aa;
private ListView entryListView;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    entryListView = (ListView) findViewById(R.id.listView1);
    int listID = R.layout.entry_layout;
    aa = new EntryAdapter(this, listID, entry);
    entryListView.setAdapter(aa);
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
    switch (id) {
    case R.id.action_add: {
        Intent intent = new Intent(MainActivity.this, AddActivity.class);
        startActivityForResult(intent, 1);
        break;
    }
    }
    return super.onOptionsItemSelected(item);
}

@Override
public void onActivityResult(int rc, int resc, Intent i) {
    super.onActivityResult(rc, resc, i);
    entryString = i.getStringArrayExtra("Entry");
    this.onNewItemAdded(entryString);
}

public void onNewItemAdded(String[] _entry){
    String key = new String();
    key = _entry[0];
    entry.add(key);
    aa.notifyDataSetChanged();   //Runs without crashing when this is removed.
}
, на ваш ArrayList в вашей деятельности не будет ссылаться ArrayList в вашем адаптере. Поэтому, когда вы изменяете запись Arraylist в своей деятельности, это не повлияет на адаптеры ArrayList. Либо измените конструктор на:


comment
Проблема скорее всего в строке key = _entry[0]. Проверьте размер записи, прежде чем вы получите индекс 0. Набор данных уведомлений был изменен, закомментирован и раскомментирован, вероятно, просто неудачное совпадение.   -  person Martin Marconcini    schedule 18.03.2015
comment
@MartínMarconcini Готово   -  person    schedule 18.03.2015
comment
@jvrodrigues Я поднял тост со значением ключа, и все было в порядке :/   -  person Bob Bob    schedule 18.03.2015
comment
Какая строка _1_   -  person Bob Bob    schedule 18.03.2015
comment
@MartínMarconcini Извините, я вас не понял? Как мне это проверить?   -  person Martin Marconcini    schedule 18.03.2015
comment
Что находится вокруг строки 66 в вашем _1_ ?   -  person Bob Bob    schedule 18.03.2015
comment
Строка 66 - это цикл for. Спасибо, что заставили меня заглянуть туда! После исправления ошибки, на которую указал @NaveenDissanayake, она зависла на синем экране. Это случалось несколько раз, когда я пытался исправить код. Оказывается, цикл while в for превращается в бесконечный цикл.   -  person Martin Marconcini    schedule 18.03.2015
comment
Рад, что вы нашли проблему, урок усвоен: в следующий раз внимательно прочитайте трассировку стека. ;)   -  person Bob Bob    schedule 19.03.2015
comment
03-18 18:38:03.840: E/AndroidRuntime(6052): НЕИСПРАВНОЕ ИСКЛЮЧЕНИЕ: main 03-18 18:38:03.840: E/AndroidRuntime(6052): Процесс: com.FirstClass.alert, PID: 6052 03-18 18:38:03.840: E/AndroidRuntime(6052): java.lang.IndexOutOfBoundsException: неверный индекс 0, размер равен 0 (ArrayList.java:255) 03-18 18:38:03.840: E/AndroidRuntime(6052): в java.util.ArrayList.get(ArrayList.java:308) 03-18 18:38:03.840: E/AndroidRuntime (6052): в com.FirstClass.netalert.EntryAdapter.getView(EntryAdapter.java:66) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.AbsListView.obtainView(AbsListView.java: 2263) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.ListView.makeAndAddView(ListView.java:1790) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.ListView.fillDown(ListView.java:691) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widg et.ListView.fillFromTop(ListView.java:752) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.ListView.layoutChildren(ListView.java:1630) 03-18 18:38: 03.840: E/AndroidRuntime(6052): в android.widget.AbsListView.onLayout(AbsListView.java:2091) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.View.layout(View .java:14822) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.ViewGroup.layout(ViewGroup.java:4631) 03-18 18:38:03.840: E/AndroidRuntime(6052 ): в android.widget.RelativeLayout.onLayout(RelativeLayout.java:1055) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.View.layout(View.java:14822) 03- 18 18:38:03.840: E/AndroidRuntime(6052): в android.view.ViewGroup.layout(ViewGroup.java:4631) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget. FrameLayout.layoutChildren(FrameLayout.java:453) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.FrameLayout.onLayout(FrameLayout .java:388) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.View.layout(View.java:14822) 03-18 18:38:03.840: E/AndroidRuntime(6052 ): в android.view.ViewGroup.layout(ViewGroup.java:4631) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.support.v7.internal.widget.ActionBarOverlayLayout.onLayout(ActionBarOverlayLayout. java:502) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.View.layout(View.java:14822) 03-18 18:38:03. 840: E/AndroidRuntime(6052): в android.view.ViewGroup.layout(ViewGroup.java:4631) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.FrameLayout.layoutChildren(FrameLayout .java:453) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.FrameLayout.onLayout(FrameLayout.java:388) 03-18 18:38:03.840: E/AndroidRuntime(6052) ): в android.view.View.layout(View.java:14822) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.ViewGroup.layout(ViewGroup.java:4631) 03- 18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.LinearLayout.setChildFrame(LinearLayout.java:1671) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget. LinearLayout.layoutVertical(LinearLayout.java:1525) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.LinearLayout.onLayout(LinearLayout.java:1434) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.View.layout(View.java:14822) 03-18 18:38:03.840: E/AndroidRuntime (6052): в android.view.ViewGroup.layout(ViewGroup.java:4631) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.widget.FrameLayout.layoutChildren(FrameLayout.java:453) 03-18 18:38:03.840: E/AndroidRuntime(6052): на android.widget.FrameLayout.onLayout(FrameLayout.java:388) 03-18 18:38:03.840: E/AndroidRuntime(6052): на android. view.View.layout(View.java:14822) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.ViewGroup.layout(ViewGroup.java:4631) 03-18 18:38: 03.840: E/AndroidRuntime(6052): в android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1987) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.ViewRootImpl.performTraversals(ViewRootImpl .java:1744) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1000) 03-18 18:38:03.840: E/AndroidRuntime(6052) ): в android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5670) 03-18 18:38:03.840: E/Andro idRuntime(6052): в android.view.Choreographer$CallbackRecord.run(Choreographer.java:761) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.Choreographer.doCallbacks(Choreographer.java :574) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.Choreographer.doFrame(Choreographer.java:544) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747) 03-18 18:38:03. 840: E/AndroidRuntime(6052): at android.os.Handler.handleCallback(Handler.java:733) 03-18 18:38:03.840: E/AndroidRuntime(6052): at android.os.Handler.dispatchMessage(Handler .java:95) 03-18 18:38:03.840: E/AndroidRuntime(6052): в android.os.Looper.loop(Looper.java:136) 03-18 18:38:03.840: E/AndroidRuntime(6052 ): в android.app.ActivityThread.main(ActivityThread.java:5021) 03-18 18:38:03.840: E/AndroidRuntime(6052): в java.lang.reflect.Method.invokeNative(собственный метод) 03-18 18:38:03.840: E/AndroidRuntime(6052): в java.lang.reflect.Method.invoke(Method.java:515) 03-18 18:38:03.840: E/AndroidRuntime(6052): в com.android .internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:827) 03-18 18:38:03.840: E/AndroidRuntime(6052): в com.android.internal.os.ZygoteInit.main(ZygoteInit.java: 643) 03-18 18:38:03.840: E/AndroidRuntime(6052): at dalvik.system.NativeStart.main(собственный метод)   -  person Martin Marconcini    schedule 21.03.2015


Ответы (2)


или измените onNewItemAdded на:

public EntryAdapter(Context _context, int _resource, List<String> _entries){
    super(_context, _resource, R.id.key, _entries);
    this.resource = _resource;
    this.entries = _entries;
    this.count = 0;
}

Моя проблема была решена путем реализации метода new ArrayList<String>(_entries); моего

public EntryAdapter(Context _context, int _resource, List<String> _entries){
    super(_context, _resource, R.id.key, _entries);
    this.resource = _resource;
    this.entries = _entries;
    this.count = 0;
}
, который помог onNewItemAdded узнать, для скольких объектов вызывать
public void onNewItemAdded(String[] _entry){
    String key = new 
    key = _entry[0];
    aa.add(key);
    aa.notifyDataSetChanged();
}
после изменения данных.

public void onNewItemAdded(String[] _entry){
    String key = new 
    key = _entry[0];
    aa.add(key);
    aa.notifyDataSetChanged();
}
person Naveen Dissanayake    schedule 18.03.2015

Опубликуйте полную трассировку стека исключений, пожалуйста.

@Override
public int getCount()
{
    return data.size();
}
person craned    schedule 05.01.2016