一、 Android平台给我们提供了一个SharedPreferences类,它是一个轻量级的存储类,特别适合用于保存软件配置参数。使用SharedPreferences保存数据,其背后是用xml文件存放数据,文件存放在/data/data//shared_prefs目录下: SharedPreferences sharedPreferences = getSharedPreferences("config", Context.MODE_PRIVATE); Editor editor = sharedPreferences.edit();//获取编辑器 editor.putString("name", "NAME"); editor.putInt("age", 4); editor.commit();//提交修改 生成的config.xml文件内容如下: NAME 因为SharedPreferences背后是使用xml文件保存数据,getSharedPreferences(name,mode)方法的第一个参数用于指定该文件的名称,名称不用带后缀,后缀会由Android自动加上。方法的第二个参数指定文件的操作模式,共有四种操作模式。如果希望SharedPreferences背后使用的xml文件能被其他应用读和写,可以指定Context.MODE_WORLD_READABLE和Context.MODE_WORLD_WRITEABLE权限。但是实际上即使用了MODE_WORLD_WRITEABLE权限,别的应用程序也是不能修改本程序的数据的 如果其他程序要修改本程序数据可以在配置文件中使用android:sharedUserId,加上shareduserid之后,写入其他程序的文件时,和权限没有关系 另外Activity还提供了另一个getPreferences(mode)方法操作SharedPreferences,这个方法默认使用当前类不带包名的类名作为文件的名称。 访问SharedPreferences中的数据代码如下: SharedPreferences sharedPreferences = getSharedPreferences("config", Context.MODE_PRIVATE); //getString()第二个参数为缺省值,如果preference中不存在该key,将返回缺省值 String name = sharedPreferences.getString("name", ""); int age = sharedPreferences.getInt("age", 1); 如果访问其他应用中的Preference,前提条件是:该preference创建时指定了Context.MODE_WORLD_READABLE或者Context.MODE_WORLD_WRITEABLE权限。如:有个为cn.itcast.action的应用使用下面语句创建了preference。 getSharedPreferences("config", Context.MODE_WORLD_READABLE); 其他应用要访问上面应用的preference,首先需要创建上面应用的Context,然后通过Context 访问preference ,访问preference时会在应用所在包下的shared_prefs目录找到preference : Context otherAppsContext = createPackageContext("cn.zql.action", Context.CONTEXT_IGNORE_SECURITY); SharedPreferences sharedPreferences = otherAppsContext.getSharedPreferences("config", Context.MODE_WORLD_READABLE); String name = sharedPreferences.getString("name", ""); int age = sharedPreferences.getInt("age", 0); 但是有一点值得注意,当使用这几种权限时,其他程序访问数据时启动本程序修改文件数据,其他程序得到的还是缓存数据得不到最新的数据, 其他程序要想得到最新数据,本程序在写文件时必须使用MODE_MULTI_PROCESS权限。 如果不通过创建Context访问其他应用的preference,可以以读取xml文件方式直接访问其他应用preference对应的xml文件,如: File xmlFile = new File(“/data/data//shared_prefs/config.xml”);//应替换成应用的包名
二 、 使用SQLite实现对数据的操作: 第一步:建立一个要操作的表对应的javabean 第二步:创建一个类,继承SQLiteOpenHelper(完成数据库和表的创建,以及软件升级时,对数据库、表结构进行更新) 第三步:创建一个类,实现对数据的CRUD(Create/Read/Update/Delete)操作(将SQLiteOpenHelper的实例传入其中,从而可以对数据库进行操作) 第四步:编写测试类,对第三步编写的CRUD操作进行测试,包括分页显示数据 第五步:配置清单文件以及布局文件
public void updateContact(Contact contact){
String sql = "update contacts set name=?,phone=? where _id=?";
Object[] bindArgs = {contact.getName(),contact.getPhone(),contact.get_id()};
dbHelper.getWritableDatabase().execSQL(sql, bindArgs);
}
三、
android中的电话本等数据就是通过ContentProvider实现数据共享的,系统中有很多已经存在的共享Uri。我们可以使用ContentResolver通过Uri来操作不同表的数据;如Contacts.People.CONTENT_URI
自定义ContentProvider中用到的类有:
(1)ContentProvider(2)SQLiteOpenHelper、 SQLiteDatabase(3)UriMatCher(方法:addURI、match)、ContentUris(方法: parseId(uri)、withAppendedId(uri))
使用ContentProvider的应用中需要用到类ContentResolver、ContentValues