ContentProvider类的解析
一、ContentProvider类
1.作用:专门用于不同应用之间进行数据共享的方式。
二、实现方法
1.创建ContenteProvider类
步骤一:继承ContentProvider接口,重写接口的方法
/*其他方法都好理解*/ public class BookProvider extends ContentProvider { @Override public boolean onCreate() { return false; } @Nullable @Override public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { return null; } @Nullable @Override /*返回一个Uri请求所对应的MIME类型,如果不关心可直接返回null*/ public String getType(Uri uri) { return null; } @Nullable @Override public Uri insert(Uri uri, ContentValues values) { return null; } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { return 0; } @Override public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { return 0; } }
步骤二:在AndroidManifest.xml中注册
<provider android:authorities="com.chen.android.provider" android:name=".BookProvider" android:process=":provider"> </provider>
其中android:authorities是Provider的唯一标识,外界应用必须声明相应的权限才能进行操作。
2.应用访问该ContentProvider
protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Uri uri = Uri.parse("content://com.chen.android.provider"); getContentResolver().query(uri,null,null,null,null); }
content://com.chen.android.provider:唯一标识了BookProvider属性。
通过Activity的ContentProvider管理器,利用Uri指定ContentProvider,并调用指定方法。
注:方法的调用是在Binder线程中的,而不是在Activity的onCreate()方法中
3.创建数据库(辅助)
如何创建数据库:SQLite的使用 和 第一行代码的示例
注:创建了名为Book和User两个Table
public class DbOpenHelper extends SQLiteOpenHelper { private static final String DBNAME = "book_provider.db"; public static final String BOOK_TABLE_NAME = "book"; public static final String USER_TABLE_NAME = "user"; private String CREATE_BOOK_TABLE = "create table if ont exists"+BOOK_TABLE_NAME+"(_id INTEGER PRIMARY KEY,name TEXT)"; private String CREATE_USER_TABLE = "create table if not exists"+USER_TABLE_NAME +"(_id INTEGER PRIMARY KEY,"+"name TEXT)"; public DbOpenHelper(Context context, int version) { super(context, DBNAME, null, version); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CREATE_USER_TABLE); db.execSQL(CREATE_BOOK_TABLE); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }