我已经成功实现了listview的延迟加载。一切正常;加载图像和文字。我有两条文字信息;名称和描述。我能够完美地显示图像和名称。但是一旦我尝试将描述包含在其中,它似乎没有问题,直到某个位置。程序在该位置被强制关闭。无法弄清楚导致它关闭的原因。知道可能是什么原因? logcat上显示的结果仅打印到要打印的项目总数的一半左右。
程序能够检索所有图像并正确显示它们。这是肯定的。但是在检索整段文本内容时遇到问题。它只检索可用文本总数的一半。
我正在使用here中的示例。
LazyAdapter.java
public class LazyAdapter extends BaseAdapter {
private Activity activity;
private String[] data;
private String[] text;
private static LayoutInflater inflater=null;
public ImageLoader imageLoader;
public LazyAdapter(Activity a, String[] d, String[] t) {
activity = a;
data=d;
text = t;
inflater = (LayoutInflater)activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
imageLoader=new ImageLoader(activity.getApplicationContext());
}
public int getCount() {
return data.length;
}
public Object getItem(int position) {
return position;
}
public long getItemId(int position) {
return position;
}
public static class ViewHolder{
public TextView text;
public ImageView image;
}
public View getView(int position, View convertView, ViewGroup parent) {
View vi=convertView;
ViewHolder holder;
if(convertView==null){
vi = inflater.inflate(R.layout.item, null);
holder=new ViewHolder();
holder.text=(TextView)vi.findViewById(R.id.text);;
holder.image=(ImageView)vi.findViewById(R.id.image);
vi.setTag(holder);
}
else
holder=(ViewHolder)vi.getTag();
holder.text.setText(text[position]);
holder.image.setTag(data[position]);
imageLoader.DisplayImage(data[position], activity, holder.image);
return vi;
}
}
logcat中的错误异常如下所示。
ERROR/AndroidRuntime(270): java.lang.ArrayIndexOutOfBoundsException
ERROR/AndroidRuntime(270): at com.lazy.LazyAdapter.getView(LazyAdapter.java:59)
ERROR/AndroidRuntime(270): at android.widget.AbsListView.obtainView(AbsListView.java:1294)
ERROR/AndroidRuntime(270): at android.widget.ListView.makeAndAddView(ListView.java:1727)
ERROR/AndroidRuntime(270): at android.widget.ListView.fillDown(ListView.java:652)
ERROR/AndroidRuntime(270): at android.widget.ListView.fillGap(ListView.java:623)
ERROR/AndroidRuntime(270): at android.widget.AbsListView.trackMotionScroll (AbsListView.java:2944)
ERROR/AndroidRuntime(270): at android.widget.AbsListView$FlingRunnable.run (AbsListView.java:2485)
ERROR/AndroidRuntime(270): at android.os.Handler.handleCallback(Handler.java:587)
ERROR/AndroidRuntime(270): at android.os.Handler.dispatchMessage(Handler.java:92)
ERROR/AndroidRuntime(270): at android.os.Looper.loop(Looper.java:123)
ERROR/AndroidRuntime(270): at android.app.ActivityThread.main(ActivityThread.java:4627)
ERROR/AndroidRuntime(270): at java.lang.reflect.Method.invokeNative(Native Method)
ERROR/AndroidRuntime(270): at java.lang.reflect.Method.invoke(Method.java:521)
ERROR/AndroidRuntime(270): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
ERROR/AndroidRuntime(270): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
ERROR/AndroidRuntime(270): at dalvik.system.NativeStart.main(Native Method)
答案 0 :(得分:1)
显然,您在LazyAdapter.java:59中在数据管理器中取消引用了一些数组/数组列表。如果这是最后一次输入,则很可能是一个错误
编写和执行有意义的单元测试可以避免这种情况。