Android应用程序组件Content Provider在应用程序之间共享数据的原理分析(6)

简介:

       Step 24. SQLiteCursor.getCount

      这个函数定义在frameworks/base/core/java/android/database/sqlite/SQLiteCursor.java文件中:
  1. public class SQLiteCursor extends AbstractWindowedCursor {  
  2.     ......  
  3.   
  4.     @Override  
  5.     public int getCount() {  
  6.         if (mCount == NO_COUNT) {  
  7.             fillWindow(0);  
  8.         }  
  9.         return mCount;  
  10.     }  
  11.   
  12.     ......  
  13. }  
      它里面的成员变量mCount的初始化为NO_COUNT,表示还没有去执行数据库查询操作,因此,还不知道它的值是多少,需要通过调用fillWindow函数来从数据据库中查询中,第三方应用程序所请求的数据一共有多少行。
 
      Step 25. QLiteCursor.fillWindow
      这个函数定义在frameworks/base/core/java/android/database/sqlite/SQLiteCursor.java文件中:
  1. public class SQLiteCursor extends AbstractWindowedCursor {  
  2.     ......  
  3.   
  4.     private void fillWindow (int startPos) {  
  5.         ......  
  6.   
  7.         mCount = mQuery.fillWindow(mWindow, mInitialRead, 0);  
  8.           
  9.         ......  
  10.     }  
  11.   
  12.     ......  
  13. }  
      注意,这里的成员变量mWindow实际上是SQLiteCursor的父类AbstractWindowedCursor的成员变量,是在Step 23中设置的,它的访问权限为protected,因此,SQLiteCursor类可以直接访问它。真正的数据库查询操作是由SQLiteCursor类的成员变量mQuery来执行的,它的类型是SQLiteCursor,是前面的Step 22中创建的,它知道如何去把第三方应用程序请求的数据从数据库中提取出来。
 
      Step 26. SQLiteCursor.fillWindow
      这个函数定义在frameworks/base/core/java/android/database/sqlite/SQLiteQuery.java文件中:
  1. public class SQLiteQuery extends SQLiteProgram {  
  2.     ......  
  3.   
  4.     /* package */ int fillWindow(CursorWindow window,  
  5.             int maxRead, int lastPos) {  
  6.         ......  
  7.         try {  
  8.             ......  
  9.             try {  
  10.                 ......  
  11.                 // if the start pos is not equal to 0, then most likely window is  
  12.                 // too small for the data set, loading by another thread  
  13.                 // is not safe in this situation. the native code will ignore maxRead  
  14.                 int numRows = native_fill_window(window, window.getStartPosition(), mOffsetIndex,  
  15.                     maxRead, lastPos);  
  16.   
  17.                 ......  
  18.                 return numRows;  
  19.             } catch (IllegalStateException e){  
  20.                 ......  
  21.             } catch (SQLiteDatabaseCorruptException e) {  
  22.                 ......  
  23.             } finally {  
  24.                 ......  
  25.             }  
  26.         } finally {  
  27.             ......  
  28.         }  
  29.     }  
  30.   
  31.     ......  
  32. }   
      这里我们可以看到,真正的数据库查询操作是由本地方法native_fill_window来执行的,它最终也是调用了sqlite的库函数来执行数据库查询的操作,这里我们就不跟进去了,对sqlite有兴趣的读者可以自己研究一下。这个函数执行完成之后,就会把从数据库中查询得到的数据的行数返回来,这个行数最终返回到Step 25中的SQLiteCursor.fillWindow函数,设置在SQLiteCursor类的成员变量mCount中,于是,下次再调用它的getCount函数时,就可以马上返回了。
 
      这一步执行完成之后,就回到前面的Step 14中,最终就把从Content Provider中查询得到的数据通过匿名共享内存返回给第三方应用程序了。
      至此,Android应用程序组件Content Provider在应用程序之间共享数据的原理就分析完成了,总的来说,它就是通过Binder进程间通信机制和匿名共享内存来实现的了。
      关于应用程序间的数据共享还有另外的一个重要话题,就是数据更新通知机制了。因为数据是在多个应用程序中共享的,当其中一个应用程序改变了这些共享数据的时候,它有责任通知其它应用程序,让它们知道共享数据被修改了,这样它们就可以作相应的处理。在下一篇文章中,我们将分析Android应用程序组件Content Provider的数据更新通知机制,敬请关注。




本文转自 Luoshengyang 51CTO博客,原文链接:http://blog.51cto.com/shyluo/967010,如需转载请自行联系原作者
目录
相关文章
|
28天前
|
搜索推荐 Android开发 iOS开发
安卓与iOS系统的用户界面设计对比分析
本文通过对安卓和iOS两大操作系统的用户界面设计进行对比分析,探讨它们在设计理念、交互方式、视觉风格等方面的差异及各自特点,旨在帮助读者更好地理解和评估不同系统的用户体验。
19 1
|
2月前
|
Android开发 数据安全/隐私保护 iOS开发
安卓与iOS系统的发展趋势与比较分析
【2月更文挑战第6天】 在移动互联网时代,安卓和iOS系统作为两大主流移动操作系统,各自呈现出不同的发展趋势。本文将从技术角度出发,对安卓和iOS系统的发展方向、特点及未来趋势进行比较分析,以期为读者提供更深入的了解和思考。
35 4
|
2月前
|
网络协议 算法 Android开发
安卓逆向 -- 实战某峰窝APP(动态分析)
安卓逆向 -- 实战某峰窝APP(动态分析)
29 4
|
2月前
|
安全 搜索推荐 Android开发
Android 与 iOS 的比较分析
【2月更文挑战第5天】 Android 和 iOS 是目前市场上两种最流行的移动操作系统,它们都拥有自己的特点和优势。本文将会分别从操作系统设计、应用生态、安全性等方面对这两种操作系统进行比较和分析,希望能够帮助读者更好地选择适合自己的移动设备。