今天做到一个小项目,查询手机中短信的信息,当然得去系统暴露出来的数据库中去查询了,后来发现有三种方式可以选择,下面一一写出来。
第一种方式,采用 getContentResolver().query()方法在主线程中查询数据。这种查询方式是不是异步查询的,直接在UI线程中查询数据,代码如下:
1 | Cursor cursor1 = getContentResolver().query(Sms.CONVESATION_URI, CONVERSATION_PROJECTION, null , null , " sms.date desc" ); |
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 )); |
第二种查询方式,这种查询同样是在UI线程中查询数据,不过这种方式得到的Cursor不用手动去关闭,是Activity自动会去关闭的,cursor由activity去管理,代码如下:
1 | Cursor cursor2 = managedQuery(Sms.CONVESATION_URI, CONVERSATION_PROJECTION, null , null , "sms.date desc" ); |
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 )); |
第三种查询方式,这种方式是利用Android提供的异步查询框架AsyncQueryHandler,/是一种异步查询方式,当单查询完毕后,会调用onQueryComplete(token, cookie, cursor)通知查询完毕,并且传回cursor。代码如下:
01 | private void startQuery() { |
02 | Uri uri = Sms.CONVESATION_URI; |
03 | mQueryHandler.startQuery( 0 , null , uri, CONVERSATION_PROJECTION, null , null , "sms.date desc" ); |
06 | private final class QueryHandler extends AsyncQueryHandler { |
07 | public QueryHandler(ContentResolver cr) { |
12 | protected void onQueryComplete( int token, Object cookie, Cursor cursor) { |
13 | super .onQueryComplete(token, cookie, cursor); |
15 | mAdapter.changeCursor(cursor); |
Android开发中性能优化始终要谨记在心,所以如果数据量稍微大点都要使用异步查询,尽量避免在UI线程中做耗时操作,而查询而言,利用Android提供好的异步查询框架是最适合的了,其实AsyncQueryHandler也是封装了Handler来实现的,还有一点,一般在查询本地的应用的数据的时候要去采用CursorAdapter。