編輯:關於android開發
來自:http://www.cnblogs.com/greatverve/archive/2012/01/13/android-SDcard.html
平時我們需要在手機上面存儲想音頻,視頻等等的大文件,以前學過使用File進行存儲(使用File操作進行存儲);由於考慮到手機本身的存儲空間小,這時候我們需要把文件存儲在SDcard中,今天自己也學習了一下在android進行sdcard的存儲使用方法;
首先如果要在程序中使用sdcard進行存儲,我們必須要在AndroidManifset.xml文件進行下面的權限設置:
在AndroidManifest.xml中加入訪問SDCard的權限如下:
<!-- 在SDCard中創建與刪除文件權限 -->
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
<!-- 往SDCard寫入數據權限 -->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
接著我們在使用SDcard進行讀寫的時候 會用到Environment類下面的幾個靜態方法
1: getDataDirectory() 獲取到Androi中的data數據目錄
2:getDownloadCacheDirectory() 獲取到下載的緩存目錄
3:getExternalStorageDirectory() 獲取到外部存儲的目錄 一般指SDcard
4:getExternalStorageState() 獲取外部設置的當前狀態 一般指SDcard,
android系統中對於外部設置的狀態,我們比較常用的應該是 MEDIA_MOUNTED(SDcard存在並且可以進行讀寫) MEDIA_MOUNTED_READ_ONLY (SDcard存在,只可以進行讀操作) 當然還有其他的一些狀態,可以在文檔中進行查找到
5:getRootDirectory() 獲取到Android Root路徑
6:isExternalStorageEmulated() 返回Boolean值判斷外部設置是否有效
7:isExternalStorageRemovable() 返回Boolean值,判斷外部設置是否可以移除
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/hello" /> <EditText android:id="@+id/et1" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <Button android:id="@+id/bt1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="使用SDcard寫操作" /> <EditText android:id="@+id/et2" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <Button android:id="@+id/bt2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="使用SDcard讀操作" /> </LinearLayout>
package com.example.yanlei.yh; import android.os.Bundle; import android.os.Environment; import android.support.v7.app.AppCompatActivity; import android.view.Menu; import android.view.MenuItem; import android.widget.TextView; import org.apache.http.util.EncodingUtils; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.List; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.os.Environment; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; public class MainActivity extends AppCompatActivity { private Button bt1, bt2; private EditText et1, et2; private static final String FILENAME = "temp_file.txt"; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); bt1 = (Button) this.findViewById(R.id.bt1); bt2 = (Button) this.findViewById(R.id.bt2); et1 = (EditText) this.findViewById(R.id.et1); et2 = (EditText) this.findViewById(R.id.et2); bt1.setOnClickListener(new MySetOnClickListener()); bt2.setOnClickListener(new MySetOnClickListener()); } private class MySetOnClickListener implements OnClickListener { @Override public void onClick(View v) { File file = new File(Environment.getExternalStorageDirectory(), FILENAME); switch (v.getId()) { case R.id.bt1:// 使用SDcard寫操作 if (Environment.getExternalStorageState().equals( Environment.MEDIA_MOUNTED)) { try { FileOutputStream fos = new FileOutputStream(file); fos.write(et1.getText().toString().getBytes()); fos.close(); Toast.makeText(MainActivity.this, "寫入文件成功", Toast.LENGTH_LONG).show(); } catch (Exception e) { Toast.makeText(MainActivity.this, "寫入文件失敗", Toast.LENGTH_SHORT).show(); } } else { // 此時SDcard不存在或者不能進行讀寫操作的 Toast.makeText(MainActivity.this, "此時SDcard不存在或者不能進行讀寫操作", Toast.LENGTH_SHORT).show(); } break; case R.id.bt2:// 使用SDcard讀操作 if (Environment.getExternalStorageState().equals( Environment.MEDIA_MOUNTED)) { try { FileInputStream inputStream = new FileInputStream(file); byte[] b = new byte[inputStream.available()]; inputStream.read(b); et2.setText(new String(b)); Toast.makeText(MainActivity.this, "讀取文件成功", Toast.LENGTH_LONG).show(); } catch (Exception e) { Toast.makeText(MainActivity.this, "讀取失敗", Toast.LENGTH_SHORT).show(); } } else { // 此時SDcard不存在或者不能進行讀寫操作的 Toast.makeText(MainActivity.this, "此時SDcard不存在或者不能進行讀寫操作", Toast.LENGTH_SHORT).show(); } break; } } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.menu_main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); //noinspection SimplifiableIfStatement if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } }
Kotlin的數據類:節省很多行代碼(KAD 10),kotlin很多行作者:Antonio Leiva 時間:Jan 25, 2017 原文鏈接:https://ant
安卓開發之RecyclerView,安卓recyclerviewRecyclerView是一個非常好用的控件,它的效果和ListView很相似,甚至可以說Recycler
細說MySQL 之MEM_ROOT這篇文章會詳細解說MySQL中使用非常廣泛的MEM_ROOT的結構體,同時省去debug部分的信息,僅分析正常情況下,mysql中使用M
android gridview畫分割線 android gridview畫分割線,如圖: 1。先上圖: 2.具體實現代碼: public class Lin