【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

相关文章

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c