ContentProvider是Android中提供的专门用于不同应用间进行数据共享的方式,从这里看他天生就适合进程间通信。ContentProvider底层也是通过Binder实现进程间通信,不过使用起来要比AIDL要简单,因为系统已经为我们进行了封装,我们不需要考虑到底层关系就可以实现IPC。
ContentProvider使用:
首先先创建一个自定义的ContentProvider,如BookProvider继承ContentProvider,其中有6个方法需要重写onCreate(),undate(),delete(),query(),insert(),getType()。其中onCreate()是代表ContentProvider的创建。getType(Uri uri)需要传入一个Uri,返回Uri所对应的MIME类型。undate(),delete(),query(),insert(),这个四个方法都是对数据库的操作方法增删改查。这六个方法中,除了onCreate()是运行在主线程中,其他的五个方法都是由外界回调并且运行到Binder线程池中。
ContentProvider主要是以表格形式来组织数据,并且可以包含多个表,对于每个表,他们都具有行和列的层次性,行对应着一条记录,列对应的一个属性,和数据库类似。同时他也支持文件数据,如图片,视频等。文件数据和表格数据不同,因此处理这类数据是可以在ContentProvider中返回文件的句柄给外界从而让文件访问ContentProvider中的文件信息。
BookProvider创建完成后,我们在去配置XML文件,其中android:authorities是ContentProvider的唯一标识,通过这个我们可以访问到ContentProvider,所以这个要是唯一的,建议在定义的时候加上包名。如果需要跨进程还需要声明“com.ryg.PROVIDER”权限。
注册完成后,我们就可以访问了,只是这里面没有东西。
现在我们添加一些数据,需要一个数据库管理,我们创建一个DpOpenHelper继承SQLiteOpenHelper,然后创建几个常量:如数据库名字:public static final String DB_NAME = "book_provider_db" 表名:public static final ?String BOOK_TABLE_NAME = "book" 创建表语句:public static final String CREATE_TABLE_BOOK = "create table " + BOOK_TABLE_NAME + "(_id INTEGER PRIMARY KEY ," + "name TEXT)" 然后再OnCreate() 执行创表语言就可以了。
然后我们就可以通过ContentProvider对表中的数据进行增删改查了。ContentProvider通过URI来区分外界要访问的数据集合,所以我们要对特定的表定义特定的URI和URI_CODE,通过UriMatcher.addURI的方法将URI和URI_CODE关联到一起如:对于这个book表格,
public static final String AUTHRITY = "com.example.book.provider";//这个是唯一标识和XML里面authrities一样。
public static final Uri BOOK_CONTENT_URI = Uri.parse("content://" + AUTHRITY + "/book");//book表格的URI
public static fianl int BOOK_URI_CODE = 1;//book表格的code
private static final UriMatcher ?uriMatcher= new UriMatcher(UriMatcher.NO_MATCH);//创建UriMatcher
static{ uriMatcher.addURI(AUTHRITY,"book",BOOK_URI_CODE); //将URI和code关联到一起。
}
然后将undate() insert() query() delete() 这几个方法完善,通过这四个方法操作数据库。不过要注意的是insert() delete() undate() 这三个方法会导致数据库里面数据发生改变,我们需要通过ContentResolver的notifychange方法通知外界当前的ContentProvider已经发生改变。