之前做一个项目,项目里面的布局是这样的:一个Viewpager,Viewpager里面有三个Fragment,在第二个Fragment里面有一个ListView,使用了BaseAdapter来显示item。当时因为图方便,把获取数据源mData的方法直接写在了adapter的构造方法里面,数据源通过syncHttpClient向后台请求参数获取。

大概的代码如下:

 private LayoutInflater mInflater;
private static List<Map<String, Object>> mData = new ArrayList<Map<String, Object>>();
private RequestQueue queue;
private ImageLoader imageLoader;
private Context context;
private UserInfoEntity userInfoEntity; public LessonEndingAdapter(Context context) {
this.context = context;
mInflater = LayoutInflater.from(context);
AuthCheck ac = new AuthCheck();
this.userInfoEntity = ac.getUserInfo(context);
queue = Volley.newRequestQueue(context);
imageLoader = new ImageLoader(queue, new BitmapCache());
init();
}
private void init() {
mData.clear();
String url = Codes.URL_ROOT + "/lesson/studied.api?" + "userid="+ context.getSharedPreferences(Codes.USERINFO, 0).getInt(Codes.USERID, 0) + "&token="+ context.getSharedPreferences(Codes.USERINFO, 0).getString(Codes.TOKEN, "");
SyncHttpClient client = new SyncHttpClient();
client.get(url, new JsonHttpResponseHandler() {
@Override
public void onSuccess(int statusCode, Header[] headers,JSONObject response) {
super.onSuccess(statusCode, headers, response);
if (statusCode == 200) {
processJsonData(response);
}
}
});
}

这里就不详细的讲SyncHttpClient的用法了,只说说我在使用过程中碰到的一些问题和解决办法。

当时我在init()中用的是AsyncHttpClient(代码里面是SyncHttpCilent),没在意AsyncHttpClient和SyncHttpClient的区别,随意挑了前者,结果问题就出现了:

第一次init没有问题,但是当init操作执行几次后,页面变成了空白一片,listView中的item都消失了。

我在adapter的init(),getView(),getCount()中都写了Log,发现init()方法中的mData成功获取了数据,但是getCount方法中显示item数目为0,而getView中的log更是直接就没打印出来。一般来说,在一个类中,代码的执行顺序肯定是:变量声明->构造方法->其他方法,所以init()应该是在getCount和getView之前执行的。现在数据获取到了,但是却没有在布局中显示出来,惯性思维下,我觉得应该是adapter出现了问题。

我先从adapter的notifyDataSetChanged()方法入手,一步步点进去,最后进入notifyChanged()方法,代码如下:

从字面上看,就是一个循环,对每一个item进行判断是否改变,若改变的话对布局进行修改。但现在的问题是getCount为0,也就是说并未进行这个循环,通过Log打印的顺序,我对getView中Log没打出来的问题有了大致的猜想:

在adapter中方法执行的顺序为:构造方法->getCount->getView,其他方法在adapter中并不是必不可少的,暂且不论。当listView绑定了一个adapter时,程序会执行构造方法,然后执行getCount(),getCount()会重复执行几遍,当getCount方法不为0时,执行getView方法。若getCount()一直为0,那么就不执行getView(),布局自然而然就不会显示出来。

现在的问题就是,数据取到了(mData有数据),但是getCount为什么一直为0呢?我想来想去也只有从第三方类库SyncHttpClient入手了。在网上查了一下SyncHttpClient和AsyncHttpClient的特性,发现字面意思已经表达的很清楚了:sync->同步,async->异步……也就是说,当用AsyncHttpClient时,程序会自动新开一个线程,数据获取在一个线程,而adapter中的getCount又在另一个线程,两者的进度是无法把握的。结果很明显了,虽然是init()方法先执行,但是由于AsyncHttpCilent新开了一个线程,导致在请求参数的过程中,getCount()也已经开始执行,AsyncHttpClient是一个较为耗时的操作,所以每次getCount都先于client.get执行完毕,这就解释了为什么getCount一直为0而mData又不为空了!

既然发现了问题那就很好解决了,最简单的方法就是把AsyncHttpClient改成SyncHttpClient。但是这样做性能很差,这就失去了异步操作存在的意义了。我的方法是在AsynHttpClient方法的末尾,即数据取完之后,加一个adapter.notifyDataSetChanged(),这时程序会自动再次执行getCount,很显然这次的getCount就不为0了,紧接着就执行getView显示布局,ok,问题解决。

使用AsyncHttpClient碰到的问题及解决方法的更多相关文章

  1. MYSQL导入大量数据碰到的问题及解决方法

    在项目中,经常会碰到往数据库中导入大量数据,以便利用sql进行数据分析.在导入数据的过程中会碰到一些需要解决的问题,这里结合导入一个大约4G的txt数据的实践,把碰到的问题以及解决方法展现出来,一方面 ...

  2. 在CentOS7.1上安装Gitlab碰到的问题及解决方法

    一 前言 关于在CentOS7上安装Gitlab, 官方文档已经很详细了,步骤大家按照官方的安装文档一步一步安装即可, 这里就不在累述.官方安装文档地址:  https://about.gitlab. ...

  3. InstallShield 工程类型MSI 使用过程中碰到的问题及解决方法。

    原文 http://www.cnblogs.com/daocaorenbx/p/InstallShield.html 一.安装完 桌面创建IE快捷方式: 1.  install script可以直接建 ...

  4. 安装opencv3.3.0碰到的问题及解决方法

    出处:http://osask.cn/front/ask/view/258965 CMakeError.log Compilation failed: source file: '/home/jhro ...

  5. 安装ftp碰到的问题及解决方法

    1   CRT显示乱码:     本地windows机器.改动SecureCRT的设置.找到"选项"->"会话选项"->"外观" ...

  6. Error:const char* 类型的实参和LPCWSTR类型的形参不兼容的解决方法。

    在C++的Windows 应用程序中经常碰到这种情况. 解决方法: 加入如下转换函数: LPCWSTR stringToLPCWSTR(std::string orig) { size_t origs ...

  7. PHP:使用Zend对源码加密、Zend Guard安装以及Zend Guard Run-time support missing的解决方法

    Zend Guard是目前市面上最成熟的PHP源码加密产品了.刚好需要对自己的产品进行加密,折腾了一晚上,终于搞定,将碰到的问题及解决方法记录下来,方便日后需要,也可以帮助其他人.我使用的是Wamps ...

  8. AsyncHttpClient 中的重定向和 setEnableRedirects 方法异常解决

    今天使用 AsyncHttpClient  开源库,遇到个很崩溃的问题: 方法  setEnableRedirects(false); 从名称上看应该是重定向开关的方法,设置为 false 后则普通请 ...

  9. 利用pyinstaller生成exe文件碰到的一些问题及解决方法

    在“开源图像标注工具labelme的安装使用及汉化”这篇博客中,使用pyinstaller将labelme项目的入口python文件main.py打包,生成了main.exe文件,可以在Windows ...

随机推荐

  1. linux VM命令下查找

    使用vi编辑器编辑长文件时,常常是头昏眼花,也找不到需要更改的内容. 这时,使用查找功能尤为重要. 方法如下: 1.命令模式下输入“/字符串”,例如“/Section 3”. 2.如果查找下一个,按“ ...

  2. android studio class org.bouncycastle.asn1.asn1primitive overrides final method equals

    好吧 上手as 又遇到一个问题: class org.bouncycastle.asn1.asn1primitive overrides final method equals... 项目运行的是后报 ...

  3. CPU acceleration status:HAXM must be updated(version 1.1.1<6.0.1)

    终于上手as了,感觉很爽 但是感觉也特闹心啊 还好有stackoverflow(这特么才是一个神奇的网站好吗) 废话少说 记录一下: 前面历经的磨难暂时不说了,就这个CPU acceleration ...

  4. 监控CPU和内存的使用

    监控CPU和内存的使用: #!/bin/bash #script to capture system statistics outfile=/home/rainbow/test/file.csv da ...

  5. 1003: A Bug

    题目链接:http://172.16.200.33/JudgeOnline/problem.php?id=1003 分析: (1)题意很简单,就是检查一堆数据中是否有同性恋,找出主要矛盾是如果1喜欢2 ...

  6. Hadoop 中 Eclipse 的配置

    先启动Hadoop守护进程,进入hadoop安装目录,执行bin/start-all.sh 主要是为了之后能正确测试 Ubuntu中下载安装Eclipse,执行sudo apt-get install ...

  7. 《A First Course in Abstract Algebra with Applications》-chaper1-数论

    由于笔者在别的专栏多次介绍过数论,这里在<抽象代数基础教程>的专栏下,对于chaper1数论这一章节介绍的方式不那么“入门”. 首先来介绍一个代数中常用也是非常重要的证明方法:数学归纳法. ...

  8. UIWebview 禁止某个方向滚动

    Enable Horizontal scrolling and disable Vertical scrolling: myWebView.scrollView.delegate = self; [m ...

  9. weekend110(Hadoop)的 第三天笔记

    (2015年1月17日) 课程目录 01-hdfs源码跟踪之打开输入流 02-hdfs源码跟踪之打开输入流总结 03-mapreduce介绍及wordcount 04-wordcount的编写和提交集 ...

  10. yii 中设置提示成功信息,错误提示信息,警告信息

    方法一: <?php Yii::app()->user->setFlash(‘success’,”Data saved!”); 设置键值名为success的临时信息.在getFlas ...