Android 异步查询框架AsyncQueryHandler的使用

AsyncQueryHandler简介: 异步的查询操作帮助类,可以处理增删改(ContentProvider提供的数据)

  • 使用场景:
    在一般的应用中可以使用ContentProvider去操作数据库。
    这在数据量很小的时候是没有问题的,但是如果数据量大了,可能导致UI线程发生ANR异常(超过5秒)。
    当然你也可以写个Handler去做这些操作,只是你每次使用ContentProvider时都要再写个Handler,必然降低了效率。
    因此当数据量较大时,最好还是使用Android已经封装好的异步查询框架AsyncQueryHandler,优化我们的代码.

  • 要注意的是,一般在查询本地的应用的数据的时候要去采用CursorAdapter。

  • AsyncQueryHandler内部实现
    AsyncQueryHandler类封装了调用者线程与工作线程的交互过程。交互的主体是两个Handler,一个运行在调用者线程中,一个运行在工作者线程中。通过提供onXXXComplete的回调接口,实现事件的完成处理。

  • API中提供
    startInsert, startDelete, startUpdate, startQuery四种方法,并有响应的onXXXComplete()方法.于对应的4个onXXXComplete()方法都是空实现,因此我们完成相应调用后进行后续其他的操作.

  • 使用方法
    继承AsyncQueryHandler类,并提供onXXXComplete方法的实现(可以实现任何一个或多个,当然你也可以一个也不实现,如果你不关注操作数据库的結果),在你的实现中做一些对数据库操作完成的处理。

  • 使用时直接调用startXXX方法即可。传入的通用参数如下:

    • token,一个令牌,主要用来标识查询,保证唯一即可.需要跟 - - onXXXComplete方法传入的一致。(当然你也可以不一致,同样在数据库的操作结束后会调用对应的onXXXComplete方法 )
    • cookie,你想传给onXXXComplete方法使用的一个对象。(没有的话传递null即可)
    • Uri uri(进行查询的通用资源标志符):
    • projection 查询的列
    • selection 限制条件
    • selectionArgs 查询参数
    • orderBy 排序条件

private void startQuery() {  

        Uri uri = Sms.CONVESATION_URI;  

        mQueryHandler.startQuery(0, null, uri, CONVERSATION_PROJECTION, null, null, "sms.date desc");  

    }  

    // 写一个异步查询类  

    private final class QueryHandler extends AsyncQueryHandler {  

        public QueryHandler(ContentResolver cr) {  

            super(cr);  

        }  



        @Override  

        protected void onQueryComplete(int token, Object cookie, Cursor cursor) {  

            super.onQueryComplete(token, cookie, cursor);  

            // 更新mAdapter的Cursor  

            mAdapter.changeCursor(cursor);  

        }  

    }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值