Android ListView异步加载图片乱序问题,原因分析及解决方案

本文转载自:http://blog.csdn.net/guolin_blog/article/details/45586553
在Android所有系统自带的控件当中,ListView这个控件算是用法比较复杂的了,关键是用法复杂也就算了,它还经常会出现一些稀奇古怪的问题,让人非常头疼。比如说在ListView中加载图片,如果是同步加载图片倒还好,但是一旦使用异步加载图片那么问题就来了,这个问题我相信很多Android开发者都曾经遇到过,就是异步加载图片会出现错位乱序的情况。遇到这个问题时,不少人在网上搜索找到了相应的解决方案,但是真正深入理解这个问题出现的原因并对症解决的人恐怕还并不是很多。那么今天我们就来具体深入分析一下ListView异步加载图片出现乱序问题的原因,以及怎么样对症下药去解决它。
本篇文章的原理基础建立在上一篇文章之上,如果你对ListView的工作原理还不够了解的话,建议先去阅读 Android ListView工作原理完全解析,带你从源码的角度彻底理解 。
问题重现
要想解决问题首先我们要把问题重现出来,这里只需要搭建一个最基本的ListView项目,然后在ListView中去异步请求图片并显示,问题就能够得以重现了,那么我们就新建一个ListViewTest项目。
项目建好之后第一个要解决的是数据源的问题,由于ListView中需要从网络上请求图片,那么我就提前准备好了许多张图片,将它们上传到了我的CSDN相册当中,然后新建一个Images类,将所有相册中图片的URL地址都配置进去就可以了,代码如下所示:
[java] view plain copy
/**
* 原文地址: http://blog.csdn.net/guolin_blog/article/details/45586553
* @author guolin
*/
public class Images {

public final static String[] imageUrls = new String[] {  
    "https://img-my.csdn.net/uploads/201508/05/1438760758_3497.jpg",    
    "https://img-my.csdn.net/uploads/201508/05/1438760758_6667.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760757_3588.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760756_3304.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760755_6715.jpeg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760726_5120.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760726_8364.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760725_4031.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760724_9463.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760724_2371.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760707_4653.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760706_6864.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760706_9279.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760704_2341.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760704_5707.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760685_5091.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760685_4444.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760684_8827.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760683_3691.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760683_7315.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760663_7318.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760662_3454.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760662_5113.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760661_3305.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760661_7416.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760589_2946.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760589_1100.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760588_8297.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760587_2575.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760587_8906.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760550_2875.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760550_9517.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760549_7093.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760549_1352.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760548_2780.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760531_1776.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760531_1380.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760530_4944.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760530_5750.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760529_3289.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760500_7871.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760500_6063.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760499_6304.jpeg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760499_5081.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760498_7007.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760478_3128.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760478_6766.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760477_1358.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760477_3540.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760476_1240.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760446_7993.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760446_3641.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760445_3283.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760444_8623.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760444_6822.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760422_2224.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760421_2824.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760420_2660.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760420_7188.jpg",  
    "https://img-my.csdn.net/uploads/201508/05/1438760419_4123.jpg",  
};  

}
设置好了图片源之后,我们需要一个ListView来展示所有的图片。打开或修改activity_main.xml中的代码,如下所示:
[html] view plain copy

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值