【Android-基础】数据存取4种方式:sp、文件存取、sqlite、contentProvide

2023-10-25 01:38

本文主要是介绍【Android-基础】数据存取4种方式:sp、文件存取、sqlite、contentProvide,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【Android-基础】

点击进入【Android-基础】的目录,获得更多学习资源


文章目录

  • 【Android-基础】
  • 前言
  • 一、SharedPreferences:最简单的
  • 二、文件存取
    • (一)文件存储之内部存储
    • (二)文件存储之外部存储
  • 三、Sqlite存储
  • 四、跨应用数据共享ContentProvide(不常用)
  • 总结


前言

安卓的四种存储数据的方式为:

1、SharedPreferences

2、文件存储(内部+外部):通过IO流读取文件

3、Sqlite

4、跨应用数据共享ContentProvide


一、SharedPreferences:最简单的

这种方式会将数据以xml文件的形式存储

存储步骤:

①取出SharedPreferences:

方式1:getSharedPreferences(文件名,权限);

方式2:getPreferences(权限);

前者适合多个SharedPreferences文件,后者如果程序只有一个SharedPreferences,就用后者。

权限:MODE_PRIVATE代表这个文件,只能被本程序使用。
MODE_MULTI_PROCESS代表这个文件可以跨应用使用。

②取出 SharedPreferences.Editor对象,调用SharedPreferences的edit方法。

③用 SharedPreferences.Editor对象存数据,用其putString、putInt等方法。

④提交存储,用SharedPreferences.Editor对象的commit方法。
取出步骤:

①取出SharedPreferences。

②用SharedPreferences的getString、getInt方法取出

代码:

public class TestActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);init();}private void init() {SharedPreferences sp = getSharedPreferences("test",MODE_MULTI_PROCESS);//存SharedPreferences.Editor editor = sp.edit();editor.putString("data","这是第一条数据");editor.commit();//取String dataStr = sp.getString("data","");//data没有值,默认取出“”System.out.println(dataStr);}
}

二、文件存取

I/O其实就是input/output,前者叫做输入流,后者叫做输出流,这个可以简单的字面理解,输入流,就是文件流输入进app。

(一)文件存储之内部存储

特点:

1、这个会将数据存在files文件下

2、默认被创建这个文件的app使用

3、app卸载,这个文件也删除

4、内部存储满了,手机就会不能用,所以尽量少用这个。

代码:

public class NeibuCunchu {public Context context;public NeibuCunchu(Context context) {this.context = context;}/*** 存储数据方法*/public void saveData(String savaDataString){FileOutputStream fos = null;try {//fileName是存储数据的文件名,后面是权限,权限参考SharedPreferences的权限fos = context.openFileOutput("fileName",Context.MODE_PRIVATE);//数据写入文件输出流fos.write(savaDataString.getBytes());//清除缓存fos.flush();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally {if (fos!=null){try {fos.close();} catch (IOException e) {e.printStackTrace();}}}}/*** 获取数据*/public void getData(){FileInputStream fis = null;try {fis = context.openFileInput("fileName");byte[] bytes = null;//初始化并用available方法设置字节数组大小bytes = new byte[fis.available()];//数据存入文件输入流fis.read(bytes);//将文件信息读出打印System.out.println(new String(bytes));} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally {if (fis!=null){try {fis.close();} catch (IOException e) {e.printStackTrace();}}}}
}

(二)文件存储之外部存储

步骤:

1、获取外部存储目录:

2、读写外部存储文件:FileInputStream和FileOutputStream

3、在AndroidManifest.xml设置读写权限。

代码:

public class WaibuCunchu {public File file;public WaibuCunchu() {//根目录创建data.txt文件作为数据存储文件this.file = new File(Environment.getExternalStorageDirectory(),"data.txt");}/*** 存储数据方法*/public void saveData(String savaDataString){FileOutputStream fos = null;try {//fos用FileOutputStream初始化fos = new FileOutputStream(file);//数据写入文件输出流fos.write(savaDataString.getBytes());//清除缓存fos.flush();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally {if (fos!=null){try {fos.close();} catch (IOException e) {e.printStackTrace();}}}}/*** 获取数据*/public void getData(){FileInputStream fis = null;try {fis = new FileInputStream(file);byte[] bytes = null;//初始化并用available方法设置字节数组大小bytes = new byte[fis.available()];//数据存入文件输入流fis.read(bytes);//将文件信息读出打印System.out.println(new String(bytes));} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally {if (fis!=null){try {fis.close();} catch (IOException e) {e.printStackTrace();}}}}
}

在AndroidManifest.xml文件中设置权限:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

三、Sqlite存储

1、优势:占用资源少、运行效率高、安全、可移植性强。

2、步骤:

(1)创库

①用openOrCreateDatabase方法

②继承SQLiteOpenHelper类

(2)操作

增删改查对应insert()\delete()\update()\query()

3、代码:

用继承SQLiteOpenHelper类方式

MyDbHelper文件:

public class MyDbHelper extends SQLiteOpenHelper {public MyDbHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {//工厂为nullsuper(context, name, null, version);}@Overridepublic void onCreate(SQLiteDatabase db) {//执行建表语句db.execSQL("create table usertable (name int, pwd int)");}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {//更新数据库处理}
}

使用的时候:

public class TestActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);init();}private void init() {//数据库存数据//参数1:上下文;参数2:库名;参数3:工厂;参数4:数据库版本MyDbHelper db = new MyDbHelper(this,"kuMing",null,1);ContentValues values = new ContentValues();values.put("name",1);values.put("pwd",1);//参数1:表名;参数2:哪个字段可以为null,null代表都不为null;参数3:要插入的数据db.getReadableDatabase().insert("usertable",null,values);//数据库取数据//参数1:查的表名;参数2:查哪一列数据,null代表查全部列数据;参数3:查询条件;参数4:查询条件的参数;后面的参数不做赘述Cursor cursor = db.getReadableDatabase().query("usertable",null,"name=?",new String[]{"1"},null,null,null);ArrayList<Map<String,String>> list = new ArrayList<>();//取下一条数据while (cursor.moveToNext()){Map<String,String> map = new HashMap<>();//取第0列赋值给namemap.put("name",cursor.getString(0));map.put("name",cursor.getString(1));list.add(map);}//展示查出的数据for (Map<String, String> map : list) {System.out.println(map.get("name")+"---"+map.get("pwd"));}}
}

四、跨应用数据共享ContentProvide(不常用)

1、知识点:

数据模型:基于数据模型的简单表格为ContentProvide提供数据

URI:统一资源标识符

2、步骤:

①继承ContentProvider

②声明权限,在AndroidManifest.xml用标签

③增删改查操作,用ContentProvide的insert()\delete()\update()\query()


总结

关于android的4中对数据持久化的存取方式,就是上面的4种了,其中比较常用的是第一种和第四种。当然,这几种都各有最适合的业务,比如“记住用户名”就可以使用第一种,比如“本地curd”就用第三种等等。 上面代码复制基本就能使用,如果有用,麻烦点个赞再走。

这篇关于【Android-基础】数据存取4种方式:sp、文件存取、sqlite、contentProvide的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/279167

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

Mybatis的分页实现方式

《Mybatis的分页实现方式》MyBatis的分页实现方式主要有以下几种,每种方式适用于不同的场景,且在性能、灵活性和代码侵入性上有所差异,对Mybatis的分页实现方式感兴趣的朋友一起看看吧... 目录​1. 原生 SQL 分页(物理分页)​​2. RowBounds 分页(逻辑分页)​​3. Page

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流