數據的存儲linux
#1.測試的相關概念 (瞭解)android
SUV 好的軟件不是開發出來的是測試出來的 jd 黑客 噹噹: -10 1.測試是否知道源代碼 黑盒測試 不知道代碼 白盒測試 知道代碼 2.按照測試的粒度 方法測試 單元測試 Junit 集成測試 系統測試 3.按照測試的暴力程度 冒煙測試 硬件 壓力測試 12306 monkey測試: adb shell下的一個測試指令。 adb shell + monkey -p packagename count;
#2.單元測試(瞭解,會用便可) 1.建立一個類集成AndroidTestCase,那麼該類就具有單元測試的功能。shell
2.須要在androidmanifest.xml中的application節點下配置一個uses-library; <uses-library android:name="android.test.runner" /> 3.須要在androidmanifest.xml中的manifest節點下配置一個instrumentation;targetPackage:須要測試的工程的包名。 <instrumentation android:name="android.test.InstrumentationTestRunner" android:targetPackage="com.itheima.junit" /> 4.若是不知道怎麼配置androidmanifest.xml,能夠新建一個android test project工程,會自動配置.
#3.Logcat日誌貓工具的使用 (會用便可)安全
包括五種級別,能夠添加過濾器過濾日誌信息。可以幫助咱們觀察程序運行的狀態。 e: w: i: d: v: 在公司開發中通常打印日誌用Log類,一般會封裝一個LogUtils,經過開關來控制日誌信息的打印。
#4.把數據存儲到文件(login案例) android 下的數據存儲服務器
1.寫佈局 LinearLayout + RelativeLayout 2.寫業務邏輯 a.找到相應控件 b.設置按鈕的點擊事件 c.在onclick方法中,獲取用戶輸入的用戶名密碼和是否記住密碼 d.判斷用戶名密碼是否爲空,不爲空請求服務器(省略,默認請求成功) e.判斷是否記住密碼,若是記住,將用戶名密碼保存本地。???? f.回顯用戶名密碼 ?? //經過context對象獲取私有目錄,/data/data/packagename/filse context.getFileDir().getPath()
#5.存儲到SD卡,獲取SD的大小及可用空間 (重點)app
使用Sdcard注意事項: 1.權限問題: <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 2.硬性編碼問題:經過 Environment能夠獲取sdcard的路徑 Environment.getExternalStorageDirectory().getPath(); 3.使用前須要判斷sdcard狀態 if(!Environment.getExternalStorageState().equals( Environment.MEDIA_MOUNTED)){ //sdcard狀態是沒有掛載的狀況 Toast.makeText(mContext, "sdcard不存在或未掛載", Toast.LENGTH_SHORT).show(); return ; } 4.須要判斷sdcard剩餘空間 //判斷sdcard存儲空間是否知足文件的存儲 File sdcard_filedir = Environment.getExternalStorageDirectory();//獲得sdcard的目錄做爲一個文件對象 long usableSpace = sdcard_filedir.getUsableSpace();//獲取文件目錄對象剩餘空間 long totalSpace = sdcard_filedir.getTotalSpace(); //將一個long類型的文件大小格式化成用戶能夠看懂的M,G字符串 String usableSpace_str = Formatter.formatFileSize(mContext, usableSpace); String totalSpace_str = Formatter.formatFileSize(mContext, totalSpace); if(usableSpace < 1024 * 1024 * 200){//判斷剩餘空間是否小於200M Toast.makeText(mContext, "sdcard剩餘空間不足,沒法知足下載;剩餘空間爲:"+usableSpace_str, Toast.LENGTH_SHORT).show(); return ; } /data/data: context.getFileDir().getPath(); 是一個應用程序的私有目錄,只有當前應用程序有權限訪問讀寫,其餘應用無權限訪問。一些安全性要求比較高的數據存放在該目錄,通常用來存放size比較小的數據。 /sdcard: Enviroment.getExternalStorageDirectory().getPath(); 是一個外部存儲目錄,只用應用聲明瞭<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>的一個權限,就能夠訪問讀寫sdcard目錄;因此通常用來存放一些安全性不高的數據,文件size比較大的數據。
#7.文件的權限概念 (瞭解)dom
//經過context對象獲取一個私有目錄的文件讀取流 /data/data/packagename/files/userinfoi.txt FileInputStream fileInputStream = context.openFileInput("userinfo.txt"); //經過context對象獲得私有目錄下一個文件寫入流; name : 私有目錄文件的名稱 mode: 文件的操做模式, 私有,追加,全局讀,全局寫 FileOutputStream fileOutputStream = context.openFileOutput("userinfo.txt", Context.MODE_PRIVATE); linux下一個文件的權限由10位標示: 1位:文件的類型,d:文件夾 l:快捷方式 -:文件 2-4: 該文件所屬用戶對本文件的權限 , rwx :用二進制標示,若是不是-就用1標示,是-用0標示;chmod指令賦權限。 5-7:該文件所屬用戶組對本文件的權限 8-10:其餘用戶對該文件的權限。
#8.SharedPreferences介紹 (重點) 用來作數據存儲工具
sharedPreferences是經過xml文件來作數據存儲的。 通常用來存放一些標記性的數據,一些設置信息。 *********使用sharedPreferences存儲數據 1.經過Context對象建立一個SharedPreference對象 //name:sharedpreference文件的名稱 mode:文件的操做模式 SharedPreferences sharedPreferences = context.getSharedPreferences("userinfo.txt", Context.MODE_PRIVATE); 2.經過sharedPreferences對象獲取一個Editor對象 Editor editor = sharedPreferences.edit(); 3.往Editor中添加數據 editor.putString("username", username); editor.putString("password", password); 4.提交Editor對象 editor.commit(); *********使用sharedPreferences讀取數據 1.經過Context對象建立一個SharedPreference對象 SharedPreferences sharedPreferences = context.getSharedPreferences("userinfo.txt", Context.MODE_PRIVATE); 2.經過sharedPreference獲取存放的數據 //key:存放數據時的key defValue: 默認值,根據業務需求來寫 String username = sharedPreferences.getString("username", ""); String password = sharedPreferences.getString("password", ""); 經過PreferenceManager能夠獲取一個默認的sharepreferences對象 SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(context);
#9 生成xml的2種方式佈局
1.寫佈局 2.業務邏輯 a.備份 1.封裝短信數據到list中 2.將list中的數據寫到xml文件中。 b.恢復 1.解析xml文件中短信數據,封裝到list集合中 2.將解析數據打印。 XmlSerializer //使用XmlSerializer來序列化xml文件 public static boolean backupSms_android(Context context){ try{ //0.獲取短信數據 ArrayList<SmsBean> allSms = SmsDao.getAllSms(); //1.經過Xml獲取一個XmlSerializer對象 XmlSerializer xs = Xml.newSerializer(); //2.設置XmlSerializer的一些參數,好比:設置xml寫入到哪一個文件中 //os:xml文件寫入流 encoding:流的編碼 xs.setOutput(context.openFileOutput("backupsms2.xml", Context.MODE_PRIVATE), "utf-8"); //3.序列化一個xml的聲明頭 //encoding:xml文件的編碼 standalone:是否獨立 xs.startDocument("utf-8", true); //4.序列化一個根節點的開始節點 //namespace:命名空間 name: 標籤的名稱 xs.startTag(null, "Smss"); //5.循環遍歷list集合序列化一條條短信 for (SmsBean smsBean : allSms) { xs.startTag(null, "Sms"); //name:屬性的名稱 value:屬性值 xs.attribute(null, "id", smsBean.id+""); xs.startTag(null, "num"); //寫一個標籤的內容 xs.text(smsBean.num); xs.endTag(null, "num"); xs.startTag(null, "msg"); xs.text(smsBean.msg); xs.endTag(null, "msg"); xs.startTag(null, "date"); xs.text(smsBean.date); xs.endTag(null, "date"); xs.endTag(null, "Sms"); } //6.序列化一個根節點的結束節點 xs.endTag(null, "Smss"); //7.將xml寫入到文件中,完成xml的序列化 xs.endDocument(); return true; }catch (Exception e) { e.printStackTrace(); } return false; }
#10.使用pull解析xml格式的數據單元測試
dom解析:基於全文加載的解析方式 sax解析:基於事件的逐行解析方式 pull解析:同sax XmlPullParser //解析xml文件讀取短信內容 public static int restoreSms(Context context) { ArrayList<SmsBean> arrayList = null; SmsBean smsBean = null; try{ //1.經過Xml獲取一個XmlPullParser對象 XmlPullParser xpp = Xml.newPullParser(); //2.設置XmlPullParser對象的參數,須要解析的是哪一個xml文件,設置一個文件讀取流 //經過context獲取一個資產管理者對象 AssetManager assets = context.getAssets(); //經過資產管理者對象能獲取一個文件讀取流 InputStream inputStream = assets.open("backupsms.xml"); xpp.setInput(inputStream,"utf-8"); //xpp.setInput(context.openFileInput("backupsms2.xml"), "utf-8"); //3.獲取當前xml行的事件類型 int type = xpp.getEventType(); //4.判斷事件類型是不是文檔結束的事件類型 while(type != XmlPullParser.END_DOCUMENT){ //5.若是不是,循環遍歷解析每一行的數據。解析一行後,獲取下一行的事件類型 String currentTagName = xpp.getName(); //判斷當前行的事件類型是開始標籤仍是結束標籤 switch (type) { case XmlPullParser.START_TAG: if(currentTagName.equals("Smss")){ //若是當前標籤是Smss,須要初始化一個集合 arrayList = new ArrayList<SmsBean>(); }else if(currentTagName.equals("Sms")){ smsBean = new SmsBean(); smsBean.id = Integer.valueOf(xpp.getAttributeValue(null, "id")); }else if(currentTagName.equals("num")){ smsBean.num = xpp.nextText(); }else if(currentTagName.equals("msg")){ smsBean.msg = xpp.nextText(); }else if(currentTagName.equals("date")){ smsBean.date = xpp.nextText(); } break; case XmlPullParser.END_TAG: //當前結束標籤是Sms的話,一條短信數據封裝完成, 能夠加入list中 if(currentTagName.equals("Sms")){ arrayList.add(smsBean); } break; default: break; } type = xpp.next();//獲取下一行的事件類型 } return arrayList.size(); }catch (Exception e) { e.printStackTrace(); } return 0; }