Android四种文件存储

Android有四种文件存储方式,分别是sharepreference,file,SQlite(数据库),内容提供者;

第二种文件存储,我们先来了解下sharepreference

简单理解,它是一种简单方便体量小的数据存储方式,通常用于存储程序的配置信息,比如控件勾选状态,登录信息;自身并不能编辑数据,只能通过他的对象editor进行编辑;

他的使用步骤是:

存储:

1,在主类中定义类成员变量shareprefence sp;

2,在主方法中初始化sp,sp=getSharePrefence;

3,获取编辑器,Editor editor =sp.edit();

4,editor.putString(“key”,”name”)/putBoolean(“key”,”false”)

5, editor.commit();提交数据

image

image

读取:

sp.getStirng(“key”,””)/sp.getBoolean(“key”,””);空内容为“ ”,也可以设置默认值“这是一个默认值”;

image

第二种文件存储:file

1,文件存储有两种方式,一种是储存在软件本身的目录下:/data/data/包名/文件名;/data/cache/包名/文件名;对应的上下文API分别是:this.getFileDir和this.getCacheDir

2,类似方便的API还有:“openFileOutput”

FileOutputStream fos = openFileOutput("info.txt", MODE_PRIVATE);等同于

File file=new File(this.getFileDir(),"info.txt");
FileOutputStream fos=new FileOutputStream(file);

image

3,初步了解几种文件访问的模式 分别是:

openFileOutput("文件名","文件的访问模式"); 私有 只读 只写 可读可写

image

 

4,文件储存于SD卡

(A)重点认识:Environment. 是内存卡相关的方便API,提供内存卡的相关上下文信息,与全局的context不同,范围更小;

/*
* 判断内存卡状态的方法是:
* 第一:Environment.getExternalStorageState()返回内存卡状态信息,返回值是String类型;
* 第二:拿到Environment.的上下文与返回值作比较即可;
*/

String state=Environment.getExternalStorageState();               
                if (Environment.MEDIA_MOUNTED.equals(state)) {

Toast.makeText(MainActivity.this, "内存卡可用"+"可用空间为"+info, 0).show();

}else{
                    Toast.makeText(MainActivity.this, "内存卡不可用", 0).show();    
        }

(B)了解formatter,并且知道如何判断外部存储大小

 

/*

*
* 获取内存存储大小方法如下:
* 第一:通过api拿到文件路径,创建文件
* 第二:通过file文件里面的getFreeSpace()方法获取可用空间
* 第三:拿到格式化器formatter对其格式化formatter.formatFileSize()即可;


image

小程序:

image

image

image

image

第三种存储方式:SQlite

数据库是一种可以存储固定格式的文件,而SQlite是一种轻量级的数据库,其创建丶存储和修改的过程是:

1,创建一个打开数据库的帮助类;

image

ps:帮助类中只是帮我们创建一个表格,数据库的升级只能由低到高;

image

2,//执行下面的一行代码,数据库是不会别创建的了。
        MyDbOpenHelper helper = new MyDbOpenHelper(this);
        //如果想创建数据库必须执行,下一行代码
        helper.getWritableDatabase();

      image

3,数据库的增删改查,可通过API进行增删改查:ps》》》每一次对数据库的操作都需要执行以下代码

MyDBOpenHelper helper = new MyDBOpenHelper(this);

SQLiteDatabase db = helper.getWritableDatabase(); 所以,在db.dao包中,一般会创建有参构造方法,写入以下代码,提高代码复用性(1,提取公共参数;2,使用dao类时,要让“对象”每次都执行,只能通过有参构造方法):

 

public class StudentDao {
   
    private StudentDBOpenHelper helper;
    /**
     * 没有无参的构造方法,只能用下面的构造方法去初始化dao
     * @param context
     */
    public StudentDao(Context context) {
        helper = new StudentDBOpenHelper(context);
    }

image

    第一:添加数据:

/**
     * 添加一条数据
     */
    public void add(View view) {
        // 执行下面的一行代码,数据库是不会别创建的了。
        MyDBOpenHelper helper = new MyDBOpenHelper(this);
        // 如果想创建数据库必须执行,下一行代码
        SQLiteDatabase db = helper.getWritableDatabase();
        Random random = new Random();
        // db.execSQL("insert into info (name,phone) values (?,?)", new Object[]
        // {
        // "王五" + random.nextInt(100), "110-" + random.nextInt(100) });
        ContentValues values = new ContentValues();
        values.put("name", "王五" + random.nextInt(100));
        values.put("phone", "110-" + random.nextInt(100));
        long id = db.insert("info", null, values);// 通过组拼sql语句
        db.close();
        if (id != -1) {
            Toast.makeText(this, "添加成功,在第" + id + "行", 0).show();
        } else {
            Toast.makeText(this, "添加失败", 0).show();
        }
    }

image

第二:修改数据

/**
     * 删除一条数据
     */
    public void delete(View view) {
        // 执行下面的一行代码,数据库是不会别创建的了。
        MyDBOpenHelper helper = new MyDBOpenHelper(this);
        // 如果想创建数据库必须执行,下一行代码
        SQLiteDatabase db = helper.getWritableDatabase();
        // db.execSQL("delete from info ");
        int result = db.delete("info", null, null);
        db.close();
        if (result == 0) {
            Toast.makeText(this, "删除失败", 0).show();
        } else {
            Toast.makeText(this, "删除了"+result+"条记录", 0).show();
            // 再去查询一次。
        }
    }

image

第三:删除数据

/**
     * 修改一条数据
     */
    public void update(View view) {
        // 执行下面的一行代码,数据库是不会别创建的了。
        MyDBOpenHelper helper = new MyDBOpenHelper(this);
        // 如果想创建数据库必须执行,下一行代码
        SQLiteDatabase db = helper.getWritableDatabase();
        //db.execSQL("update info set phone=?", new Object[] { "8888" });
        ContentValues values = new ContentValues();
        values.put("phone", "99999");
        int result = db.update("info", values, null, null);
        db.close();
        if (result == 0) {
            Toast.makeText(this, "修改了0条记录", 0).show();
        } else {
            Toast.makeText(this, "修改了"+result+"条记录", 0).show();
        }
    }

image

第四:查询数据

/**
     * 查询全部数据
     */
    public void query(View view) {
        // 执行下面的一行代码,数据库是不会别创建的了。
        MyDBOpenHelper helper = new MyDBOpenHelper(this);
        // 如果想创建数据库必须执行,下一行代码
        SQLiteDatabase db = helper.getReadableDatabase();
        //Cursor cursor = db.rawQuery("select * from info", null);
        Cursor cursor = db.query("info", new String[]{"name","phone","_id"}, null, null, null, null, null);
        while (cursor.moveToNext()) {
            String name = cursor.getString(0);
            String phone = cursor.getString(1);
            String id = cursor.getString(2);
            System.out.println("id:" + id + "--name:" + name + "--phone"
                    + phone);
            System.out.println("----");
        }
        // 记得用完数据库 关闭cursor
        cursor.close();
        db.close();
    }

image

转载于:https://my.oschina.net/shpxhk/blog/659657

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值