分為:內(nèi)部存儲(chǔ)和外部存儲(chǔ)
為通榆等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及通榆網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、通榆網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
如何區(qū)分內(nèi)部存儲(chǔ)和外部存儲(chǔ):可以從物理和邏輯區(qū)分
從物理的角度區(qū)分,內(nèi)部存儲(chǔ)就是手機(jī)自帶存儲(chǔ)空間,外部存儲(chǔ)就是外部接入的存儲(chǔ)空間例如SD卡
從邏輯意義上區(qū)分,data,system 目錄就是手機(jī)的內(nèi)部存儲(chǔ),而 mnt 或者 storage目錄下的sdcard0指向的sdcard目錄就是外部存儲(chǔ)。如果是手機(jī)自帶的外部存儲(chǔ)被稱為機(jī)身外部存儲(chǔ),外置的SD卡則稱之為外部存儲(chǔ)。當(dāng)然兩者都稱為外部存儲(chǔ)也沒(méi)關(guān)系。這里描述的內(nèi)部存儲(chǔ)和機(jī)身外部存儲(chǔ)都屬于機(jī)身存儲(chǔ);
邏輯區(qū)分是從4.4以上版本開始的;
獲取內(nèi)部存儲(chǔ)路徑和api對(duì)應(yīng)關(guān)系
1,通過(guò)Environment
2,通過(guò)上下文Context
Build.VERSION_CODES.LOLLIPOP及以上版本新增的API
Build.VERSION_CODES.N及以上版本新增的API
特點(diǎn):
1、內(nèi)部存儲(chǔ)路徑中的文件是分類存儲(chǔ)的,我們無(wú)法干涉,除了cache目錄,別的目錄系統(tǒng)不會(huì)自動(dòng)創(chuàng)建
2、除了files目錄,別的目錄我們幾乎都是無(wú)法手動(dòng)操作的
3、別的App幾乎無(wú)法訪問(wèn)內(nèi)部存儲(chǔ)中的數(shù)據(jù),除了用非法手段或者我們主動(dòng)暴露
4、內(nèi)部存儲(chǔ)目錄下的文件夾及文件會(huì)隨著app的卸載而被系統(tǒng)自動(dòng)刪除
外部存儲(chǔ)又可分為共有目錄和私有目錄;
私有目錄
私有目錄:不需要訪問(wèn)權(quán)限
Android 在外部存儲(chǔ)空間中也提供了特殊目錄供App存放私有文件,該路徑為:/storage/emulated/0/Android/data/包名/
注意:應(yīng)用安裝之后/storage/emulated/0/Android/data/是沒(méi)有對(duì)應(yīng)的應(yīng)用文件夾的,需要手動(dòng)調(diào)用對(duì)應(yīng)的API創(chuàng)建;
獲取私有目錄路徑
共有目錄
共有目錄:需要申請(qǐng)權(quán)限才能訪問(wèn)
權(quán)限:6.0以上需要?jiǎng)討B(tài)申請(qǐng)
獲取共有目錄的API 29中已過(guò)時(shí):
參考如下代碼:
package com.Aina.Android;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
import android.app.AlertDialog;
import android.app.ListActivity;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class Test_ListFile extends ListActivity {
/** Called when the activity is first created. */
private ListString items = null;//存放名稱
private ListString paths = null;//存放路徑
private String rootPath = "/";
private TextView tv;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
tv = (TextView) this.findViewById(R.id.TextView);
this.getFileDir(rootPath);//獲取rootPath目錄下的文件.
}
public void getFileDir(String filePath) {
try{
this.tv.setText("當(dāng)前路徑:"+filePath);// 設(shè)置當(dāng)前所在路徑
items = new ArrayListString();
paths = new ArrayListString();
File f = new File(filePath);
File[] files = f.listFiles();// 列出所有文件
// 如果不是根目錄,則列出返回根目錄和上一目錄選項(xiàng)
if (!filePath.equals(rootPath)) {
items.add("返回根目錄");
paths.add(rootPath);
items.add("返回上一層目錄");
paths.add(f.getParent());
}
// 將所有文件存入list中
if(files != null){
int count = files.length;// 文件個(gè)數(shù)
for (int i = 0; i count; i++) {
File file = files[i];
items.add(file.getName());
paths.add(file.getPath());
}
}
ArrayAdapterString adapter = new ArrayAdapterString(this,
android.R.layout.simple_list_item_1, items);
this.setListAdapter(adapter);
}catch(Exception ex){
ex.printStackTrace();
}
}
@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
super.onListItemClick(l, v, position, id);
String path = paths.get(position);
File file = new File(path);
//如果是文件夾就繼續(xù)分解
if(file.isDirectory()){
this.getFileDir(path);
}else{
new AlertDialog.Builder(this).setTitle("提示").setMessage(file.getName()+" 是一個(gè)文件!").setPositiveButton("OK", new DialogInterface.OnClickListener(){
public void onClick(DialogInterface dialog, int which) {
}
}).show();
}
}
}
String appPath = getApplicationContext().getPackageResourcePath();
/data/app/com.younghare.lepusService-2/base.apk
getApplicationContext().getFilesDir()
getApplicationContext().getFilesDir().getParent()
其實(shí)就是/data/data/包(這是沙盒其他app無(wú)法訪問(wèn))
String dataAppPath = getApplicationContext().getFilesDir().getParent();
new File(dataAppPath+"/databases/task.db").exists();//返回是true
抽象路徑名的絕對(duì)路徑名字符串
String appAbsolute = getApplicationContext().getFilesDir().getAbsolutePath()
/data/user/0/com.younghare.lepusService/files
獲取CachDir
getApplicationContext().getCacheDir()
通過(guò)Context.getExternalCacheDir()方法可以獲取到 SDCard/ android /data/你的應(yīng)用包名/cache/目錄,一般存放臨時(shí)緩存數(shù)據(jù)
getApplicationContext().getExternalCacheDir()
/storage/emulated/0/Android/data/com.younghare.lepusService/cache
getExternalFilesDir(null)參數(shù)傳入的為null,這樣默認(rèn)訪問(wèn)的是files文件夾,我們可以指定子文件夾
一、在Android應(yīng)用中的XML文件來(lái)源
1、本地xml文件
本地XML文件可以放在應(yīng)用根目錄assets文件夾、res/xml、res/raw、SDcard卡、應(yīng)用的data目錄等;
除res/xml可直接通過(guò)getXml(int id)獲取XML文檔,返回一個(gè)解析器對(duì)象(XmlResourceParer:XmlResourceParer是XmlPullParser的子類),其它位置情況都可以獲取XML文檔,返回一個(gè)Inputstream對(duì)象,進(jìn)行讀取數(shù)據(jù),獲取方法分別如下:
a.在res/xml目錄下(推薦使用):
[java] view plaincopy
XmlResourceParser xmlParser = this.getResources().getXml(R.xml.XXX);
b.在res/xml、res/raw目錄下:
[java] view plaincopy
InputStream inputStream = this.getResources().openRawResource(R.xml.XXX);
c.在assets文件夾下(本人測(cè)試發(fā)現(xiàn)通過(guò)此方法獲取的XML文檔不能帶有首行:?xml version="1.0" encoding="utf-8"?,否則解析報(bào)錯(cuò),具體原因未查明,知道原因請(qǐng)回復(fù)交流):
[java] view plaincopy
InputStream inputStream = getResources().getAssets().open(fileName);
d.在應(yīng)用指定目錄下(SDcard,應(yīng)用data目錄等):
[java] view plaincopy
// path路徑根據(jù)實(shí)際項(xiàng)目修改,此次獲取SDcard根目錄
String path = Environment.getExternalStorageDirectory().toString();
File xmlFlie = new File(path+fileName);
InputStream inputStream = new FileInputStream(xmlFlie);
2、通過(guò)url得到的xml文件
很多時(shí)候需要解析xml文件都用于客戶端與服務(wù)器之間的數(shù)據(jù)交互,比如解析google天氣預(yù)報(bào)信息,或自己項(xiàng)目?jī)?nèi)定的一些XML數(shù)據(jù)結(jié)構(gòu),其中通過(guò)URL,使用DefaultHTTPClient get請(qǐng)求獲取XML文件方法如下:
[java] view plaincopy
/**
* 讀取url的xml資源 轉(zhuǎn)成String
* @param url
* @return 返回 讀取url的xml字符串
*/
public String getStringByUrl(String url) {
String outputString = "";
// DefaultHttpClient
DefaultHttpClient httpclient = new DefaultHttpClient();
// HttpGet
HttpGet httpget = new HttpGet(url);
// ResponseHandler
ResponseHandlerString responseHandler = new BasicResponseHandler();
try {
outputString = httpclient.execute(httpget, responseHandler);
outputString = new String(outputString.getBytes("ISO-8859-1"), "utf-8"); // 解決中文亂碼
Log.i("HttpClientConnector", "連接成功");
} catch (Exception e) {
Log.i("HttpClientConnector", "連接失敗");
e.printStackTrace();
}
httpclient.getConnectionManager().shutdown();
return outputString;
}
二、XML文件的解析方式
能夠運(yùn)用在Android系統(tǒng)上解析XML文件的常用有三種方式:DOM、SAX和PULL,其中DOM解析XML是先把XML文件讀進(jìn)內(nèi)存中,再通過(guò)接口獲取數(shù)據(jù),該方法使用相對(duì)小的XML文件,移動(dòng)設(shè)備往往受硬件性能影響,如果XML文件比較大使用DOM解析往往效率跟不上;SAX和PULL都是采用事件驅(qū)動(dòng)方式來(lái)進(jìn)行解析,在Android中的事件機(jī)制是基于回調(diào)函數(shù)。
本例旨在考慮簡(jiǎn)單方便性,綜合考慮選擇了PULL解析,PULL解析器是一個(gè)開源項(xiàng)目,Android平臺(tái)已經(jīng)內(nèi)置了PULL解析器,同時(shí)Android系統(tǒng)本身也是使用PULL解析器來(lái)解析各種XML文檔。
1、事件回調(diào)類型
PULL解析XML文件時(shí),回調(diào)XmlResourceParser內(nèi)定義表示文檔開頭結(jié)束和節(jié)點(diǎn)開頭結(jié)束的數(shù)值(事件回調(diào)類型),表示如下:
a.讀取到XML文檔開頭(聲明)返回:XmlPullParser.START_DOCUMENT(0)
b.讀取到XML文檔結(jié)束返回:XmlPullParser.END_DOCUMENT (1)
c.讀取到XML節(jié)點(diǎn)開始返回:XmlPullParser.START_TAG (2)
d.讀取到XML節(jié)點(diǎn)結(jié)束返回:XmlPullParser.END_TAG (3)
e.讀取到XML文本返回:XmlPullParser.TEXT (4)
2、XmlPullParser有幾個(gè)主要方法(更多查閱Android APIs):
a.XmlPullParser.getEventType() : Returns the type of the current event (START_TAG, END_TAG, TEXT, etc.) 【獲取當(dāng)前事件回調(diào)類型】
b.XmlPullParser.getName():For START_TAG or END_TAG events, the (local) name of the current element is returned when namespaces are enabled.【獲取當(dāng)前節(jié)點(diǎn)名字】
c.XmlPullParser.getAttributeValue(int index):Returns the given attributes value.【根據(jù)id獲取節(jié)點(diǎn)屬性值】
d.XmlPullParser.getAttributeValue(String namespace, String name):Returns the attributes value identified by namespace URI and namespace localName.【根據(jù)name獲取節(jié)點(diǎn)屬性值】
e.XmlPullParser.netxText():If current event is START_TAG then if next element is TEXT then element content is returned or if next event is END_TAG then empty string is returned, otherwise exception is thrown.【回調(diào)節(jié)點(diǎn)START_TAG時(shí),通過(guò)此方法獲取節(jié)點(diǎn)內(nèi)容】
3、實(shí)際編碼中如何使用
在實(shí)際編碼中,主要根據(jù)事件回調(diào)類型,結(jié)合被解析的XML結(jié)構(gòu)進(jìn)行解析提取數(shù)據(jù),PULL解析XML文件的主要模式如下,更具體使用看本文提供的例子:
[java] view plaincopy
try {
//開始解析事件
int eventType = parser.getEventType();
//處理事件,不碰到文檔結(jié)束就一直處理
while (eventType != XmlPullParser.END_DOCUMENT) {
//因?yàn)槎x了一堆靜態(tài)常量,所以這里可以用switch
switch (eventType) {
case XmlPullParser.START_DOCUMENT:
// 不做任何操作或初開始化數(shù)據(jù)
break;
case XmlPullParser.START_TAG:
// 解析XML節(jié)點(diǎn)數(shù)據(jù)
// 獲取當(dāng)前標(biāo)簽名字
String tagName = parser.getName();
if(tagName.equals("XXXTAGXXX")){
// 通過(guò)getAttributeValue 和 netxText解析節(jié)點(diǎn)的屬性值和節(jié)點(diǎn)值
}
break;
case XmlPullParser.END_TAG:
// 單節(jié)點(diǎn)完成,可往集合里邊添加新的數(shù)據(jù)
break;
case XmlPullParser.END_DOCUMENT:
break;
}
// 別忘了用next方法處理下一個(gè)事件,不然就會(huì)死循環(huán)
eventType = parser.next();
}
} catch (XmlPullParserException e) {
e.printStackTrace();
}catch (IOException e) {
e.printStackTrace();
}
android手機(jī)獲取自帶存儲(chǔ)路徑和sd卡存儲(chǔ)路徑的方式是:調(diào)用Environment.getExternalStorageDirectory(),返回的存儲(chǔ)目錄并不是系統(tǒng)內(nèi)置的SD卡目錄。
1.一部分手機(jī)將eMMC存儲(chǔ)掛載到 /mnt/external_sd 、/mnt/sdcard2 等節(jié)點(diǎn),而將外置的SD卡掛載到 Environment.getExternalStorageDirectory()這個(gè)結(jié)點(diǎn)。
此時(shí),調(diào)用Environment.getExternalStorageDirectory(),則返回外置的SD的路徑。
2.而另一部分手機(jī)直接將eMMC存儲(chǔ)掛載在Environment.getExternalStorageDirectory()這個(gè)節(jié)點(diǎn),而將真正的外置SD卡掛載到/mnt/external_sd、/mnt/sdcard2 等節(jié)點(diǎn)。
此時(shí),調(diào)用Environment.getExternalStorageDirectory(),則返回內(nèi)置的SD的路徑。
本文標(biāo)題:android指定路徑,安卓常見文件路徑
當(dāng)前路徑:http://vcdvsql.cn/article4/dsdieie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司、網(wǎng)站制作、App開發(fā)、微信公眾號(hào)、企業(yè)網(wǎng)站制作、用戶體驗(yàn)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)