共计 3054 个字符,预计需要花费 8 分钟才能阅读完成。
本篇文章为大家展示了 Android 数据有哪些存储方式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
ContentProvider 是安卓平台中,在不同应用程序之间实现数据共享的一种机制。一个应用程序如果需要让别的程序可以操作自己的数据,即可采用这种机制。并且此种方式忽略了底层的数据存储实现,ContentProvider 提供了一种统一的通过 Uri 实现数据操作的方式。其步骤为:
1. 在当前应用程序中定义一个 ContentProvider。
2. 在当前应用程序的 AndroidManifest.xml 中注册此 ContentProvider
3. 其他应用程序通过 ContentResolver 和 Uri 来获取此 ContentProvider 的数据。
ContentResolver 提供了诸如 insert(), delete(), query() 和 update() 之类的方法。用于实现对 ContentProvider 中数据的存取操作。
Uri 是一个通用资源标志符,将其分为 A,B,C,D 4 个部分:
A:无法改变的标准前缀,包括;content://、tel:// 等。当前缀是 content:// 时,说明通过一个 Content Provider 控制这些数据
B:URI 的标识,它通过 authorities 属性声明,用于定义了是哪个 ContentProvider 提供这些数据。对于第三方应用程序,为了保证 URI 标识的唯一性,它必须是一个完整的、小写的 类名。例如; content://com.test.data.myprovider
C:路径,可以近似的理解为需要操作的数据库中表的名字,如:content://hx.android.text.myprovider/name 中的 name
D:如果 URI 中包含表示需要获取的记录的 ID;则就返回该 id 对应的数据,如果没有 ID,就表示返回全部;
下面通过是代码示例,演示一下如何在应用之间相互获取数据。
在应用程序 A 中,继承 ContProvider 类,并重写其中方法。
public class MyProvider extends ContentProvider{
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
// TODO Auto-generated method stub
return 0;
}
@Override
public String getType(Uri uri) {
// TODO Auto-generated method stub
return null;
}
@Override
public Uri insert(Uri uri, ContentValues values) {
return null;
}
// 在 Create 中初始化一个数据库
@Override
public boolean onCreate() { SQLiteDatabase db = this.getContext().openOrCreateDatabase(test_db.db3 , Context.MODE_PRIVATE, null);
db.execSQL(create table tab(_id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL)
ContentValues values = new ContentValues();
values.put( name , test
db.insert(tab , _id , values);
db.close();
return true;
}
// 实现 query 方法
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String sortOrder) { SQLiteDatabase db = this.getContext().openOrCreateDatabase(test_db.db3 , Context.MODE_PRIVATE, null);
Cursor c = db.query(tab , null, null, null, null, null,null);
return c;
}
@Override
public int update(Uri uri, ContentValues values, String selection,
String[] selectionArgs) {
// TODO Auto-generated method stub
return 0;
}
}
在其 AndroidManifest.xml 中声明此 ContentProvider,其中 authorities 属性定义了此 ContentProvider 的 Uri 标识。
provider android:name= .MyProvider android:authorities= com.test.MyProvider /
在应用程序 B 中,通过 ContentResolver 获取程序 A 的 ContentProvider 中的数据。
public class MainActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);
setContentView(R.layout.main);
// 获取上下文
Context ctx = MainActivity.this;
// 获取 ContentResolver 对象
ContentResolver resolver = ctx.getContentResolver();
// 获取 Uri 对象
Uri uri = Uri.parse( content://com.test.MyProvider
// 获取数据
Cursor c = resolver.query(uri, null, null, null, null);
c.moveToFirst();
for(int i=0; i c.getCount(); i++){
int index = c.getColumnIndexOrThrow( name
String src = c.getString(index);
Log.d(, src);
c.moveToNext();
}
}
}
应用程序 B 的运行结果如下,从此图可以发现我们在程序 B 中成功的获取到了程序 A 中的数据:
再观察两个应用程序的结构,如下图,其中红框是应用程序 A 的程序结构,可以清楚看到其有一个名为“test_db.db3”的数据库,蓝框是应用程序 B 的程序结构,其并没有任何数据库用于存储数据。由此图,可以确定应用程序 B 中查询出来的数据结果是来自于应用程序 A。
上述内容就是 Android 数据有哪些存储方式,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注丸趣 TV 行业资讯频道。