第一种方式,采用 getContentResolver().query()方法在主线程中查询数据。这种查询方式是不是异步查询的,直接在UI线程中查询数据,代码如下:

Java代码
  1. Cursorcursor1=getContentResolver().query(Sms.CONVESATION_URI,CONVERSATION_PROJECTION,null,null,"sms.datedesc");
  2. while(cursor1.moveToNext()){
  3. Log.i("cursor1",String.valueOf(cursor1.getInt(0)));
  4. Log.i("cursor1",cursor1.getString(1));
  5. Log.i("cursor1",cursor1.getString(2));
  6. }
  7. cursor1.close();

第二种查询方式,这种查询同样是在UI线程中查询数据,不过这种方式得到的Cursor不用手动去关闭,是Activity自动会去关闭的,cursor由activity去管理,代码如下:

Java代码
  1. Cursorcursor2=managedQuery(Sms.CONVESATION_URI,CONVERSATION_PROJECTION,null,null,"sms.datedesc");
  2. while(cursor2.moveToNext()){
  3. Log.i("cursor2",String.valueOf(cursor2.getInt(0)));
  4. Log.i("cursor2",cursor2.getString(1));
  5. Log.i("cursor2",cursor2.getString(2));
  6. }

第三种查询方式,这种方式是利用Android提供的异步查询框架AsyncQueryHandler,/是一种异步查询方式,当单查询完毕后,会调用onQueryComplete(token, cookie, cursor)通知查询完毕,并且传回cursor。代码如下:

Java代码
  1. privatevoidstartQuery(){
  2. Uriuri=Sms.CONVESATION_URI;
  3. mQueryHandler.startQuery(0,null,uri,CONVERSATION_PROJECTION,null,null,"sms.datedesc");
  4. }
  5. //写一个异步查询类
  6. privatefinalclassQueryHandlerextendsAsyncQueryHandler{
  7. publicQueryHandler(ContentResolvercr){
  8. super(cr);
  9. }
  10. @Override
  11. protectedvoidonQueryComplete(inttoken,Objectcookie,Cursorcursor){
  12. super.onQueryComplete(token,cookie,cursor);
  13. //更新mAdapter的Cursor
  14. mAdapter.changeCursor(cursor);
  15. }
  16. }

Android开发中性能优化始终要谨记在心,所以如果数据量稍微大点都要使用异步查询,尽量避免在UI线程中做耗时操作,而查询而言,利用Android提供好的异步查询框架是最适合的了,其实AsyncQueryHandler也是封装了Handler来实现的,还有一点,一般在查询本地的应用的数据的时候要去采用CursorAdapter。

更多相关文章

  1. 2019 Android开发趋势及必备技术点!
  2. Android(安卓)网络编程 Socket Http
  3. Android之Volley框架加载网络图片的三种方式
  4. Android(安卓)Intent实现页面跳转
  5. Android经典底部选项卡集成方式之一
  6. 14天学会安卓开发(第十天)Android网络与通讯
  7. Android(安卓)Studio配置AspectJ(使用jar包的方法)
  8. Android(安卓)中隐藏虚拟按键的方法实例代码
  9. Android(安卓)Architecture Components 部分源码代码分析

随机推荐

  1. mysql数据库utf-8编码
  2. 机智的MySQL优化器 --- is null
  3. 我需要PHP页面显示mysql数据库中的BLOB图
  4. 利用Intellij+MAVEN搭建Spring+Mybatis+M
  5. MySQL、JDBC安装以及用java连接
  6. mySql中SUBSTRING_INDEX函数用法
  7. mysql数据库之单表查询
  8. MYSQL如何导出存储过程和触发器?
  9. mysql百万级查询怎么样才能快速查询呢
  10. MySQL5.7 GTID学习笔记