亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

詳解Android四種存儲方式

2020-04-11 11:09:17
字體:
來源:轉載
供稿:網友

在Android程序開發中我們經常遇到四種數據存儲方式,每種存儲方式都各有不同;以下我分別列舉了Android開發中的不同存儲方式的特點

一,Preferences

Preferences是一個較輕量級的存儲數據的方法,具體使用方法:

在A中保存值:

SharedPreferences.Editor sharedata = getSharedPreferences("data", 0).edit(); sharedata.putString("name","shenrenkui"); sharedata.commit(); 

在B中取值:

SharedPreferences sharedata = getSharedPreferences("data", 0); String data = sharedata.getString("name", null); Log.i(TAG,"data="+data); 

注 意,Context.getSharedPreferences(String name,int type)的參數更我們在創建數據的時候的數據權限屬性是一樣的,存儲和取值的過程這有點像HashMap但是比HashMap更具人性 化,getXXX(Object key,Object defualtReturnValue),第二個參數是當你所要的key對應沒有時候返回的值。這就省去了很多邏輯判斷。。。。

二,Files

在Android上面沒有的File就是J2se中的純種File了,可見功能之強大,這里就算是走馬觀花地嚴重路過了。

//創建文件file = new File(FILE_PATH , FILE_NAME);file.createNewFile();//打開文件file的OutputStreamout = new FileOutputStream(file);String infoToWrite = "紙上得來終覺淺,絕知此事要躬行";//將字符串轉換成byte數組寫入文件out.write(infoToWrite.getBytes());//關閉文件file的OutputStreamout.close();//打開文件file的InputStreamin = new FileInputStream(file);//將文件內容全部讀入到byte數組int length = (int)file.length();byte[] temp = new byte[length];in.read(temp, 0, length);//將byte數組用UTF-8編碼并存入display字符串中display = EncodingUtils.getString(temp,TEXT_ENCODING);//關閉文件file的InputStreamin.close();} catch (IOException e) {//將出錯信息打印到LogcatLog.e(TAG, e.toString());this.finish();}//從資源讀取InputStream is=getResources().getRawResource(R.raw.文件名)

三,Databases

Android 內嵌了功能比其他手機操作系統強大的關系型數據庫sqlite3,我們在大學時候學的SQL語句基本都可以使用,我們自己創建的數據可以用adb shell來操作。具體路徑是/data/data/package_name/databases。如,這里演示一下進入 com.android.providers.media包下面的操作。

1, adb shell2, cd /data/data/com.android.providers.media/databases3, ls(查看com.android.providers.media下面的數據庫)4, sqlite3 internal.db5, .help---看看如何操作6, .table列出internal數據中的表7, select * from albums;DatabaseHelper mOpenHelper;private static final String DATABASE_NAME = "dbForTest.db";private static final int DATABASE_VERSION = 1;private static final String TABLE_NAME = "diary";private static final String TITLE = "title";private static final String BODY = "body";private static class DatabaseHelper extends SQLiteOpenHelper {DatabaseHelper(Context context) {super(context, DATABASE_NAME, null, DATABASE_VERSION);}@Overridepublic void onCreate(SQLiteDatabase db) {String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE+ " text not null, " + BODY + " text not null " + ");";Log.i("haiyang:createDB=", sql);db.execSQL(sql);}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}}/*** 重新建立數據表*/private void CreateTable() {SQLiteDatabase db = mOpenHelper.getWritableDatabase();String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE+ " text not null, " + BODY + " text not null " + ");";Log.i("haiyang:createDB=", sql);try {db.execSQL("DROP TABLE IF EXISTS diary");db.execSQL(sql);setTitle("數據表成功重建");} catch (SQLException e) {setTitle("數據表重建錯誤");}}/*** 刪除數據表*/private void dropTable() {SQLiteDatabase db = mOpenHelper.getWritableDatabase();String sql = "drop table " + TABLE_NAME;try {db.execSQL(sql);setTitle("數據表成功刪除:" + sql);} catch (SQLException e) {setTitle("數據表刪除錯誤");}}/*** 插入兩條數據*/private void insertItem() {SQLiteDatabase db = mOpenHelper.getWritableDatabase();String sql1 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY+ ") values('haiyang', 'android的發展真是迅速啊');";String sql2 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY+ ") values('icesky', 'android的發展真是迅速啊');";try {Log.i("haiyang:sql1=", sql1);Log.i("haiyang:sql2=", sql2);db.execSQL(sql1);db.execSQL(sql2);setTitle("插入兩條數據成功");} catch (SQLException e) {setTitle("插入兩條數據失敗");}}/*** 刪除其中的一條數據*/private void deleteItem() {try {SQLiteDatabase db = mOpenHelper.getWritableDatabase();db.delete(TABLE_NAME, " title = 'haiyang'", null);setTitle("刪除title為haiyang的一條記錄");} catch (SQLException e) {}}/*** 在屏幕的title區域顯示當前數據表當中的數據的條數。*/private void showItems() {SQLiteDatabase db = mOpenHelper.getReadableDatabase();String col[] = { TITLE, BODY };Cursor cur = db.query(TABLE_NAME, col, null, null, null, null, null);Integer num = cur.getCount();setTitle(Integer.toString(num) + " 條記錄");}

四,Network

這是借助Internet來存儲我們要的數據,這是CS結構的存儲方式,也是點一下名了。

如何使用 Content Provider

下邊是用戶經常接觸到的幾個典型Content Provider應用:

* Content Provider Name : Intended Data* Browser : Browser bookmarks, Browser history, etc.* CallLog : Missed calls, Call datails, etc.* Contacts : Contact details* MediaStore : Media files such as audio, Video and Images* Settings : Device Settings and Preferences

調用Content Provider資源的標準URI結構:

<standard_prefix>://<authority>/<data_path>/<id>

例如:

1) 取得瀏覽器所有“書簽”信息: content://browser/bookmarks
2) 取得系統通訊錄中的信息: content://contacts/people (如果取得某一個特定通訊記錄,在路徑URI的末端指定一個ID號:content://contacts/people/5

簡單的實例片段:

Uri allCalls = Uri.parse("content://call_log/calls");Cursor c = managedQuery(allCalls, null, null, null, null);

以上內容是小編給大家介紹的Android四種存儲方式,希望大家喜歡,更多信息請登錄武林網網站了解更多。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩不卡合集视频| 久久久精品国产亚洲| 国产精品久久久久久久美男| 国产精品成人aaaaa网站| 国产一区二区三区欧美| 欧美二区乱c黑人| 色午夜这里只有精品| 日韩av色在线| 久久久这里只有精品视频| 色先锋久久影院av| 亚洲精品网址在线观看| 久久99久国产精品黄毛片入口| 亚洲欧美色婷婷| www.美女亚洲精品| 欧美高清在线观看| 日韩精品视频在线播放| 九九九久久国产免费| 成人黄色免费看| 欧美电影免费播放| 欧美成人免费小视频| 亚洲美女av在线| 九九久久久久99精品| 日韩成人在线网站| 亚洲91av视频| 久久久91精品国产一区不卡| 青草青草久热精品视频在线观看| 亚洲人精品午夜在线观看| 成人夜晚看av| 欧美成年人视频| 国产一区二区三区三区在线观看| 国产欧美日韩亚洲精品| 国产欧美日韩精品专区| 亚洲欧美国产制服动漫| 97视频人免费观看| 成人精品一区二区三区| 日韩av电影手机在线观看| 亚洲免费成人av电影| 中国人与牲禽动交精品| 91精品国产高清久久久久久91| 美女视频久久黄| 国产精品扒开腿做爽爽爽视频| 国产精品激情av电影在线观看| 韩国视频理论视频久久| 亚洲女人天堂成人av在线| 国产精品白嫩初高中害羞小美女| 在线精品国产成人综合| 精品欧美国产一区二区三区| 亚洲国产中文字幕在线观看| 亚洲在线免费观看| 俺去亚洲欧洲欧美日韩| 亚洲综合小说区| 亚洲aaa激情| 欧美极品少妇xxxxⅹ喷水| 欧美日韩在线视频一区二区| 日韩在线观看高清| 亚洲欧美一区二区激情| 久久久av亚洲男天堂| 欧美在线一级视频| 亚洲在线观看视频网站| 亚洲精品电影在线观看| 国产精品久久久久99| 人妖精品videosex性欧美| 国产成人精品免费久久久久| 国产精品久久久久久久久久久久久久| 成人羞羞国产免费| 亚洲综合视频1区| 国产成人精品久久二区二区91| 亚洲国产免费av| 欧美猛少妇色xxxxx| 国模叶桐国产精品一区| 国产精品久久久久久久久免费看| 日韩av电影手机在线观看| 亚洲精品美女免费| 午夜免费在线观看精品视频| 国产美女精品视频免费观看| 久久久精品免费| 国产精品成熟老女人| 国产精品网站大全| 国产极品精品在线观看| 欧美黑人又粗大| 一区二区欧美久久| 亚洲欧美在线一区二区| 欧美成人在线免费| 美女福利视频一区| 热re99久久精品国产66热| 亚洲国产精品va在看黑人| 亚洲在线观看视频| 欧美在线免费视频| 欧美日韩成人黄色| 在线观看国产精品淫| 国产精品免费久久久| 国产成人精品久久二区二区| 精品中文字幕在线观看| 国产精品扒开腿爽爽爽视频| 精品人伦一区二区三区蜜桃免费| 午夜精品一区二区三区视频免费看| 疯狂欧美牲乱大交777| 91精品国产91久久久久久最新| 26uuu国产精品视频| 日本精品久久久| 国产精品精品一区二区三区午夜版| 国产精品一久久香蕉国产线看观看| 国内精品模特av私拍在线观看| 欧美精品在线观看| 九九九久久久久久| 国产69精品久久久久9| 亚洲人线精品午夜| 久久夜色精品国产欧美乱| 日韩中文字幕免费看| 国产欧美精品一区二区三区介绍| 成人黄色av播放免费| 久久激情五月丁香伊人| 欧美性猛交xxxx乱大交3| 国外成人在线直播| 亚洲最大福利网站| 欧美性xxxx极品hd欧美风情| 久久91亚洲人成电影网站| 精品国产一区二区三区久久| www.色综合| 国产精品久久久一区| 粉嫩老牛aⅴ一区二区三区| 久久精品国产69国产精品亚洲| 欧美激情免费在线| 精品色蜜蜜精品视频在线观看| 久久久精品2019中文字幕神马| 欧美激情国内偷拍| 久久综合网hezyo| 久久精品99久久香蕉国产色戒| 亚洲性线免费观看视频成熟| 久久精品这里热有精品| 精品国产区一区二区三区在线观看| 伊人伊人伊人久久| 久久久久久久久爱| 国产精品黄视频| 国产精品视频区| 日韩视频―中文字幕| 日本久久91av| 日韩一区二区av| 久久久成人精品| 亚洲人成在线电影| 日韩免费在线电影| 色婷婷久久av| 美女999久久久精品视频| 理论片在线不卡免费观看| 欧美午夜影院在线视频| 久久激情视频久久| 国产精品色悠悠| 国内精品在线一区| 亚洲一区二区中文| 91精品视频在线| 精品国产福利在线| 欧美日韩国产一区二区三区| 亚洲人成77777在线观看网| 91精品国产自产在线老师啪| 国产在线高清精品| 亚洲久久久久久久久久久| 国产成人精品国内自产拍免费看| 欧美在线www| 亚洲午夜性刺激影院| 欧美视频在线观看免费| 久久理论片午夜琪琪电影网| 欧美日韩国产丝袜另类| 国产视频久久久久久久| 不卡av日日日|