1.Android中的持久化技术主要有三种:
1)文件存储;
2)SharedPreference存储;
3)数据库存储(SQLite);
2.文件存储:
1)Context 类中提供了一个 openFileOutput() 方法,可以用于将数据存储到指定的文件中。
--openFileOutput() 方法的两个参数:
①文件名,不包括路径(路径默认为/data/data/<packagename>/files/);
②文件的操作模式,主要有两种:MODE_PRIVATE 和 MODE_APPEND,MODE_PRIVATE是默认的操作模式,表示操作文件时将覆盖文件内容,MODE_APPEND则是继续在文件中添加内容;
--该方法的返回值为 FileOutputStream 对象,可使用 Java IO流来进行操作;
2)Context 类还提供了一个openFileInput() 方法,该方法用于读取文件;
--该方法只有一个参数,即文件名;
--返回值为 FileInputStream 对象;
3)文件存储的方式并不适合用于保存一些较为复杂的文本数据;
2.SharedPreference存储:
1)SharedPreferences 是使用键值对的方式来存储数据的;
2)Android中 使用 SharedPreferences 对象来存储数据,有三种方式获取SharedPreferences对象:
① Context 类中的 getSharedPreferences()方法:它有两个参数,第一个是文件名,若文件不存在,则自动创建,文件存储在/data/data/<packagename>/shared_prefs/目录下;第二个参数是指定操作模式,主要有两:MODE_PRIVATE 和 MODE_MULTI_PROCESS,MODE_PRIVATE是默认模式,表示只有当前应用可以对这个 SharedPreferences 文件进行读写;MODE_MULTI_PROCESS用于多个进程对一个SharedPreferences文件进行读写;
② Activity 类中的 getPreferences()方法:它只接收一个操作模式参数,因为使用这个方法时会自动将当前活动的类名作为 SharedPreferences 的文件名;
③ PreferenceManager 类中的 getDefaultSharedPreferences() 方法:这是一个静态方法,它接收一个Context 参数,并自动使用当前应用程序的包名作为前缀来命名SharedPreferences 文件。
3)使用 SharedPreferences 对象来存储数据:
① 调用SharedPreferences 对象的edit()方法来获取一个SharedPreferences.Editor 对象。
② 向SharedPreferences.Editor 对象中添加数据,比如添加一个布尔型数据就使用 putBoolean 方法,添加一个字符串则使用putString()方法,以此类推。
③ 调用commit()方法将添加的数据提交,从而完成数据存储操作。
④ 读取数据时可以使用SharedPreferences 对象的 getXXX()方法读取,如 getString(),getInt()等,getXXX() 方法有两个参数,第一个为键名,第二个为默认值,当无法找到匹配键名的内容时使用该默认值;
3.SQLite数据库存储:
1)SQLite 是一款轻量级的关系型数据库,它的运算速度非常快,占用资源少;
2)Android 提供了一个 SQLiteOpenHelper 帮助类,借助这个类就可以非常简单地对数据库进行创建和升级;它是一个抽象类,使用时需自定义类来继承它,并重写onCreate() 方法和 onUpgrade() 方法;
3)SQLiteOpenHelper 中提供了两个方法: getReadableDatabase() 和 getWritableDatabase()。这两个方法都可以创建或打开一个现有的数据库(如果数据库已存在则直接打开,否则创建一个新的数据库),并返回一个可对数据库进行读写操作的对象。不同的是,当数据库不可写入的时候(如磁盘空间已满)getReadableDatabase()方法返回的对象将以只读的方式去打开数据库,而getWritableDatabase()方法则将出现异常。
4)CRUD操作:
--insert(table, null, contentValues):插入数据;
--update(table, contentValues, where, whereArgs):修改数据;
--delete(table, where, whereArgs):删除数据;
--query(table, columns, selection, selectionArgs, groupBy, having, orderBy):查询数据;
--可以直接通过 sql 语句来操作数据库,其中增删改可以使用 SQLiteDatabase 的 execSQL(sql) 方法,查询可以使用 rawQuery(sql) 方法;
5)事务的使用:
--调用 SQLiteDatabase 的 beginTransaction() 方法来开启事务;
--若所有操作都执行完毕,则调用 setTransactionSuccessful() 方法表示事务执行成功;
--最后在finally 中调用 endTransaction() 方法结束事务;
6)SQLite升级技巧:
--在 onUpgrade() 方法中使用 switch(oldVersion) 判断旧版本是哪一个版本,然后执行响应的升级操作;
--switch 的每一个 case 分支中都不使用 break语句,这样可以保证任何版本在升级时可以升级到最新的版本;
4.总结:文件适用于存储一些简单的文本数据或者二进制数据,SharedPreferences 适用于存储一些键值对,而数据库则适用于存储那些复杂的关系型数据;