您好,登錄后才能下訂單哦!
這篇文章主要介紹了Android數據存儲方式是什么的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Android數據存儲方式是什么文章都會有所收獲,下面我們一起來看看吧。
在開發過程中,數據存取是較為頻繁的,今天我們來了解下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數據能被其他應用程序寫。該模式已棄用。
屬于Android四大組件之一,用于進程間進行數據交互,從而能夠讓其他的應用保存或讀取此Content Provider的各種數據類型。簡單來說,一個程序可以通過實現一個Content Provider的抽象接口將自己的數據暴露出去。外界根本看不到,也不用看到這個應用暴露的數據在應用當中是如何存儲的,或者是用數據庫存儲還是用文件存儲,還是通過網上獲得。
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數據存儲方式是什么”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Android數據存儲方式是什么”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。