定义AsyncTask子类

private class LoadContactsTask extends AsyncTask<Void, Void, List<TxrjContact>> {

    /* (non-Javadoc)
     * @see android.os.AsyncTask#doInBackground(Params[])
     */
    @Override
    protected List<TxrjContact> doInBackground(Void... params) {
        List<TxrjContact> contacts = ContactDataManager.getContacts(mContext);
        return contacts;
    }
    /* (non-Javadoc)
     * @see android.os.AsyncTask#onPreExecute()
     */
    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        mProgressDialog = ProgressDialog.show(mContext,
                null, "loading contacts, please wait a moment");
    }
    /* (non-Javadoc)
     * @see android.os.AsyncTask#onPostExecute(java.lang.Object)
     */
    @Override
    protected void onPostExecute(List<TxrjContact> result) {
        super.onPostExecute(result);
        mContacts = result;
        mListAdapter = new ContactListAdapter(mContext, mContacts, mQuickAlphaBar);
        mListView.setAdapter(mListAdapter);
        mProgressDialog.dismiss();
    }
}

在onCreate方法中使用AsyncTask

new LoadContactsTask().execute();

 

定义AsyncQueryHandler的子类

private class AsyncQueryContacts extends AsyncQueryHandler {

    public AsyncQueryContacts(ContentResolver cr) {
        super(cr);
    }
    @Override
    protected void onQueryComplete(int token, Object cookie, Cursor c) {
        List<TxrjContact> contacts = new ArrayList<TxrjContact>();
        HashMap<Integer, TxrjContact> contactMap = new HashMap<Integer, TxrjContact>();
        if(c != null) {
            while(c.moveToNext()) {
                int contactId = c.getInt(c.getColumnIndex(Data.CONTACT_ID));
                TxrjContact contact = null;
                if(contactMap.containsKey(contactId)) {
                    contact = contactMap.get(contactId);
                } else {
                    contact = new TxrjContact();
                    contact.setContactId(contactId);
                    contact.setName(c.getString(c.getColumnIndex(Phone.DISPLAY_NAME)));
                    contact.setSortKey(c.getString(c.getColumnIndex("sort_key")));
                    contactMap.put(contactId, contact);
                    contacts.add(contact);
                }
                TxrjPhone phone = new TxrjPhone();
                phone.setId(c.getInt(c.getColumnIndex(Data._ID)));
                phone.setRawContactId(c.getInt(c.getColumnIndex(Data.RAW_CONTACT_ID)));
                phone.setContactId(c.getInt(c.getColumnIndex(Data.CONTACT_ID)));
                phone.setNumber(c.getString(c.getColumnIndex(Phone.NUMBER)));
                phone.setType(c.getString(c.getColumnIndex(Phone.TYPE)));
                phone.setLabel(c.getString(c.getColumnIndex(Phone.LABEL)));
                contact.getPhoneList().add(phone);
            }
            c.close();
        }
        mContacts = contacts;
        mListAdapter = new ContactListAdapter(mContext, mContacts, mQuickAlphaBar);
        mListView.setAdapter(mListAdapter);
        mProgressDialog.dismiss();
        super.onQueryComplete(token, cookie, c);
    }
}

在onCreate方法中使用AsyncQueryHandler

private AsyncQueryContacts asyncQuery;

asyncQuery = new AsyncQueryContacts(getContentResolver());
mProgressDialog = ProgressDialog.show(mContext,
        null, "loading contacts, please wait a moment");
asyncQuery.startQuery(0, null, Data.CONTENT_URI,
    new String[] {Data._ID, Data.CONTACT_ID, Data.RAW_CONTACT_ID,
        Phone.DISPLAY_NAME, Phone.NUMBER, Phone.TYPE, Phone.LABEL, "sort_key"},
    Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'",
    null, "sort_key COLLATE LOCALIZED asc");

AsyncTask和AsyncQueryHandler之比较的更多相关文章

  1. StrictMode使用详解

    http://hb.qq.com/a/20110914/000054.htm http://www.android100.org/html/201204/25/1097.html http://www ...

  2. Android 第二波

    三面,4个技术人员面试的问题不是很难.问题如下: 1. Service两种方式的区别 首先说service分为两种,一种是绑定的一种是非绑定的非绑定的生命周期是 onCreate(),onStartC ...

  3. App优化 StrictMode 严格模式

    StrictMode简介 StrictMode最常用来捕捉应用程序的主线程,它将报告与线程及虚拟机相关的策略违例.一旦检测到策略违例policy violation,你将获得警告,其包含了一个栈tra ...

  4. [转发]Android 系统稳定性 - ANR(三)

    文章都为原创,转载请注明出处,未经允许而盗用者追究法律责任. 很久之前写的了,留着有点浪费,共享之. 编写者:李文栋 http://rayleeya.iteye.com/blog/1956056 1. ...

  5. [转]【安卓笔记】AsyncTask源码剖析

    [转][安卓笔记]AsyncTask源码剖析 http://blog.csdn.net/chdjj/article/details/39122547 前言: 初学AsyncTask时,就想研究下它的实 ...

  6. Android 旋转屏幕--处理Activity与AsyncTask的最佳解决方案

    一.概述 运行时变更就是设备在运行时发生变化(例如屏幕旋转.键盘可用性及语言).发生这些变化,Android会重启Activity,这时就需要保存activity的状态及与activity相关的任务, ...

  7. Android笔记——AsyncTask介绍

    AsyncTask和Handler对比 1 ) AsyncTask实现的原理,和适用的优缺点 AsyncTask,是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操 ...

  8. Android线程管理之AsyncTask异步任务

    前言: 前面几篇文章主要学习了线程以及线程池的创建与使用,今天来学习一下AsyncTask异步任务,学习下AsyncTask到底解决了什么问题?然而它有什么弊端?正所谓知己知彼百战百胜嘛! 线程管理相 ...

  9. Android中使用AsyncTask实现文件下载以及进度更新提示

    Android提供了一个工具类:AsyncTask,它使创建需要与用户界面交互的长时间运行的任务变得更简单.相对Handler来说AsyncTask更轻量级一些,适用于简单的异步处理,不需要借助线程和 ...

随机推荐

  1. Android系列教程(十六) 在电脑上装Android

    [软件准备] 1.LiveAndroid v0.3 liveCD [点击下载] 2.VirtualBox 3.0.4 [点击下载]       [图片安装流程]       主要安装思路为:通过vir ...

  2. Spring+Quartz 集群

    这几天给Spring+Quartz的集群折腾得死去活来,google了无数页总算搞定,记下一些要点备以后使用. 单独的Quartz集群在http://unmi.blogjava.net/有Unmi翻译 ...

  3. td顶部对齐

    <td width=568 colspan=3 valign="top" style='width:426.1pt;border:none; border-bottom:so ...

  4. fisher精确检验(fisher’s exat test)和超几何分布

  5. 【BZOJ】【2750】【HAOI2012】Road

    最短路+拓扑序DP orz zyf & lyd 统计每条边在多少条最短路径上……其实可以统计 有多少条最短路径经过了x,以及y出发到达任意一个结束点有多少种走法(沿最短路) 我们可以用Dijk ...

  6. codeforces 560 C Gerald&#39;s Hexagon

    神精度--------这都能过.随便算就好了,根本不用操心 就是把六边形补全成三角形.然后去掉补的三个三角形,然后面积除以边长1的三角形的面积就可以.... #include<map> # ...

  7. GUI程序设计

    1. 对话框(JDialog)使用示例 例1. JDialog简单使用示例. import javax.swing.JLabel; public class demoJDialog { JFrame ...

  8. cesiumjs学习笔记之三——cesium-navigation插件 【转】

    http://blog.csdn.net/Prepared/article/details/68940997?locationNum=10&fps=1 插件源码地址:https://githu ...

  9. python 分词计算文档TF-IDF值并排序

    文章来自于我的个人博客:python 分词计算文档TF-IDF值并排序 该程序实现的功能是:首先读取一些文档,然后通过jieba来分词,将分词存入文件,然后通过sklearn计算每一个分词文档中的tf ...

  10. 【Storm】学习笔记

    Storm 1 基本概念 1.1 分布式.可扩展.高容错.实时流处理.跨语言 1.2 应用场景 1.2.1 实时分析 1.2.2 在线机器学习 1.2.3 分布式RPC 1.2.4 ETL数据抽取 1 ...