Android數據存儲方式操作模式解析
SharedPreferences
在開發過程中,數據存取是較為頻繁的,今天我們來瞭解下android幾種常見的數據存取方式。
在Android中,sharePreferences是一種輕量級的數據存儲方式,采用鍵值對的存儲方式,存儲少量數據,支持基本類型的簡單數據存儲。
基本用法
- 根據Context獲取SharedPreferences對象
- 利用edit()方法獲取Editor對象。
- 通過Editor對象存儲key-value鍵值對數據。
- 通過commit()方法提交數據。
public class MainActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); //獲取SharedPreferences對象 Context ctx = MainActivity.this; //第一個參數指定存儲文件名,第二個參數指定操作模式 SharedPreferences sp = ctx.getSharedPreferences("SP", MODE_PRIVATE); //存入數據 Editor editor = sp.edit(); editor.putString("STRING_KEY", "string"); editor.putInt("INT_KEY", 0); editor.putBoolean("BOOLEAN_KEY", true); editor.commit(); //返回STRING_KEY的值 設定默認值 Log.d("SP", sp.getString("STRING_KEY", "none")); //如果NOT_EXIST不存在,則返回值為"none" Log.d("SP", sp.getString("NOT_EXIST", "none")); //刪除指定數據 editor.remove("STRING_KEY"); editor.commit(); //清空數據 editor.clear(); editor.commit(); } }
操作模式
- MODE_PRIVATE 指定該SharedPreferences數據隻能被本應用程序讀、寫。這是默認模式。
- MODE_APPEND 該模式會檢查文件是否存在,存在就將數據寫到文件末尾,否則就創建新文件。
- MODE_WORLD_READABLE指定該SharedPreferences數據能被其他應用程序讀,但不能寫。該模式已棄用。
- MODE_WORLD_WRITEABLE指定該SharedPreferences數據能被其他應用程序寫。該模式已棄用。
ContentProvider
基本概念
屬於Android四大組件之一,用於進程間進行數據交互,從而能夠讓其他的應用保存或讀取此Content Provider的各種數據類型。簡單來說,一個程序可以通過實現一個Content Provider的抽象接口將自己的數據暴露出去。外界根本看不到,也不用看到這個應用暴露的數據在應用當中是如何存儲的,或者是用數據庫存儲還是用文件存儲,還是通過網上獲得。
統一資源標識符(URI)
content://com.example.myapplication.provider/tablename/1
- content 主題名,URI前綴。
- com.example.myapplication.provider 授權信息,Content Provider唯一標識符。
- tablename Content Provider 指向數據庫中的某個表名。
- 1 表中某個記錄,若無指定,返回全部記錄。
基本使用
創建Content Provider
- 創建一個繼承瞭ContentProvider父類的類
- 定義一個名為CONTENT_URI,並且是
public static final
的Uri類型的類變量,必須為其指定一個唯一的字符串值,最好的方案是以類的全名稱。 - 創建數據存儲系統。大多數Content Provider使用Android文件系統或SQLite數據庫來保持數據,但是也可以以任何你想要的方式來存儲。但是,必須為其定義一個叫_id的列,它用來表示每條記錄的唯一性。
示例代碼(存儲用戶名稱並顯示用戶名稱,使用SQLite)
public class MyUsers { public static final String AUTHORITY = “com.wissen.MyContentProvider”; // BaseColumn類中已經包含瞭 _id字段 public static final class User implements BaseColumns { public static final Uri CONTENT_URI = Uri.parse(content://com.example.MyContentProvider”); // 表數據列 public static final String USER_NAME = “USER_NAME”; } }
如上代碼定義瞭Content Provider的Content_URI和數據列,然後再基於此定義Content Provider類。
package com.wissen.testApp.android; public class MyContentProvider extends ContentProvider { private SQLiteDatabase sqlDB; private DatabaseHelper dbHelper; private static final String DATABASE_NAME = “Users.db”; private static final int DATABASE_VERSION = 1; private static final String TABLE_NAME = “User”; private static final String TAG = “MyContentProvider”; //定義SQLite接口 private static class DatabaseHelper extends SQLiteOpenHelper { DatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { //創建用於存儲數據的表 db.execSQL(”Create table ” + TABLE_NAME + “( _id INTEGER PRIMARY KEY AUTOINCREMENT, USER_NAME TEXT);”); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL(”DROP TABLE IF EXISTS ” + TABLE_NAME); onCreate(db); } } @Override public int delete(Uri uri, String s, String[] as) { return 0; } @Override public String getType(Uri uri) { return null; } @Override public Uri insert(Uri uri, ContentValues contentvalues) { sqlDB = dbHelper.getWritableDatabase(); long rowId = sqlDB.insert(TABLE_NAME, “”, contentvalues); if (rowId > 0) { Uri rowUri = ContentUris.appendId(MyUsers.User.CONTENT_URI.buildUpon(), rowId).build(); getContext().getContentResolver().notifyChange(rowUri, null); return rowUri; } throw new SQLException(”Failed to insert row into ” + uri); } @Override public boolean onCreate() { dbHelper = new DatabaseHelper(getContext()); return (dbHelper == null) ? false : true; } @Override public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { SQLiteQueryBuilder qb = new SQLiteQueryBuilder(); SQLiteDatabase db = dbHelper.getReadableDatabase(); qb.setTables(TABLE_NAME); Cursor c = qb.query(db, projection, selection, null, null, null, sortOrder); c.setNotificationUri(getContext().getContentResolver(), uri); return c; } @Override public int update(Uri uri, ContentValues contentvalues, String s, String[] as) { return 0; } }
如上所示,我們封裝瞭SQLite操作於Content Provider,是我們可以不再關註數據源的操作細節,而直接使用Content Provider進行數據的存取。
文件存儲
Android文件存儲可以用來存放大量數據,如文本、圖片、音頻等。使用方法類似於java文件存儲。
基本使用
文件寫入
public void save() { try { FileOutputStream outStream=this.openFileOutput("a.txt",Context.MODE_WORLD_READABLE) outStream.write(text.getText().toString().getBytes()); outStream.close(); //成功消息提示 Toast.makeText(MyActivity.this,"Saved",Toast.LENGTH_LONG).show(); } catch (Exception e) { e.printStackTrace(); } }
寫入文件若不存在,則會創建一個新的文件,保存在/data/data/files
文件目錄下。
文件讀取
public void load() { try { FileInputStream inStream=this.openFileInput("a.txt"); ByteArrayOutputStream stream=new ByteArrayOutputStream(); //分塊讀取 byte[] buffer=new byte[1024]; int length=-1; while((length=inStream.read(buffer))!=-1) { stream.write(buffer,0,length); } stream.close(); inStream.close(); text.setText(stream.toString()); Toast.makeText(MyActivity.this,"Loaded",Toast.LENGTH_LONG).show(); } catch (Exception e) { e.printStackTrace(); } }
總結
本文簡單介紹瞭Android幾個簡單的數據存儲方式,包括簡單數據存取,文件存儲,以及如何封裝Content Provider,更多關於Android數據存儲操作模式的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- 使用SharedPreferences在Android存儲對象詳細代碼
- Android SharedPreferences存取操作以及封裝詳解
- Android中的存儲詳解
- Android ContentProvider基礎應用詳解
- android文件存儲和SharedPreferences存儲的項目實例