Android - 延迟加载listview的问题

时间:2011-12-12 07:36:04

标签: android listview lazy-loading

我已经成功实现了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)

1 个答案:

答案 0 :(得分:1)

显然,您在LazyAdapter.java:59中在数据管理器中取消引用了一些数组/数组列表。如果这是最后一次输入,则很可能是一个错误

编写和执行有意义的单元测试可以避免这种情况。