Android 【问题汇总】列表数组越界的问题

遇到了一个诡异的问题,ListView发生数组越界(偶尔会),程序崩溃。

错误信息如下:

    W/dalvikvm( ): threadid=: thread exiting with uncaught exception (group=0x40015568)
E/zhe800_android( ): Invalid index , size is
E/zhe800_android( ): java.lang.IndexOutOfBoundsException: Invalid index , size is
E/zhe800_android( ): at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:)
E/zhe800_android( ): at java.util.ArrayList.get(ArrayList.java:)
E/zhe800_android( ): at android.widget.HeaderViewListAdapter.getView(HeaderViewListAdapter.java:)
E/zhe800_android( ): at android.widget.AbsListView.obtainView(AbsListView.java:)
E/zhe800_android( ): at android.widget.ListView.makeAndAddView(ListView.java:)
E/zhe800_android( ): at android.widget.ListView.fillUp(ListView.java:)
E/zhe800_android( ): at android.widget.ListView.fillGap(ListView.java:)
E/zhe800_android( ): at android.widget.AbsListView.trackMotionScroll(AbsListView.java:)
E/zhe800_android( ): at android.widget.AbsListView$FlingRunnable.run(AbsListView.java:)
E/zhe800_android( ): at android.os.Handler.handleCallback(Handler.java:)
E/zhe800_android( ): at android.os.Handler.dispatchMessage(Handler.java:)
E/zhe800_android( ): at android.os.Looper.loop(Looper.java:)
E/zhe800_android( ): at android.app.ActivityThread.main(ActivityThread.java:)
E/zhe800_android( ): at java.lang.reflect.Method.invokeNative(Native Method)
E/zhe800_android( ): at java.lang.reflect.Method.invoke(Method.java:)
E/zhe800_android( ): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:)
E/zhe800_android( ): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:)
E/zhe800_android( ): at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime( ): FATAL EXCEPTION: main
E/AndroidRuntime( ): java.lang.IndexOutOfBoundsException: Invalid index , size is
E/AndroidRuntime( ): at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:)
E/AndroidRuntime( ): at java.util.ArrayList.get(ArrayList.java:)
E/AndroidRuntime( ): at android.widget.HeaderViewListAdapter.getView(HeaderViewListAdapter.java:)
E/AndroidRuntime( ): at android.widget.AbsListView.obtainView(AbsListView.java:)
E/AndroidRuntime( ): at android.widget.ListView.makeAndAddView(ListView.java:)
E/AndroidRuntime( ): at android.widget.ListView.fillUp(ListView.java:)
E/AndroidRuntime( ): at android.widget.ListView.fillGap(ListView.java:)
E/AndroidRuntime( ): at android.widget.AbsListView.trackMotionScroll(AbsListView.java:)
E/AndroidRuntime( ): at android.widget.AbsListView$FlingRunnable.run(AbsListView.java:)
E/AndroidRuntime( ): at android.os.Handler.handleCallback(Handler.java:)
E/AndroidRuntime( ): at android.os.Handler.dispatchMessage(Handler.java:)
E/AndroidRuntime( ): at android.os.Looper.loop(Looper.java:)
E/AndroidRuntime( ): at android.app.ActivityThread.main(ActivityThread.java:)
E/AndroidRuntime( ): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( ): at java.lang.reflect.Method.invoke(Method.java:)
E/AndroidRuntime( ): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:)
E/AndroidRuntime( ): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:)
E/AndroidRuntime( ): at dalvik.system.NativeStart.main(Native Method)
W/ActivityManager( ): Force finishing activity com.tuan800.tao800/.activities.CategoryDealActivity

从错误日志看,没有定位到具体的问题所在。

跟踪ListView的源码,可以看出来是与Adapter绑定的数据源存在数组越界。

因为此时,可能会有两个甚至多个线程同时修改数据源。

导致这个问题的发生。

上一篇:《逐梦旅程 WINDOWS游戏编程之从零开始》笔记8——载入三维模型&Alpha混合技术&深度测试与Z缓存


下一篇:《逐梦旅程 WINDOWS游戏编程之从零开始》笔记9——游戏摄像机&三维地形的构建