【Flutter 面试题】Flutter如何进行本地存储和缓存数据?

【Flutter 面试题】Flutter如何进行本地存储和缓存数据?

文章目录

    • 写在前面
    • 口述回答
    • 补充说明
      • 实际案例
      • 完整代码示例
      • 运行结果
      • 详细说明

写在前面

🙋 关于我 ,小雨青年 👉 CSDN博客专家,GitChat专栏作者,阿里云社区专家博主,51CTO专家博主。2023博客之星TOP153。

👏🏻 正在学 Flutter 的同学,你好!

😊 Flutter 面试宝典是解决 Flutter 面试过程中可能出现的问题,而进行汇总整理的。一个问题一篇文章,优化答案,更适合面试过程中的口述满足实际面试需求

🔍 想解决开发中的高频零散问题?碎片化教程 👉 Flutter Tips

🔍 想深入学习 Flutter?系统化教程 👉 Flutter 从0到1 基础入门到应用上线全攻略 & 专栏指引

👥 快来和我们一起交流!👉 讨论群在这里,和大家一起进步!

口述回答

在构建 Flutter 应用时,合理选择本地存储数据缓存机制对于优化性能和提升用户体验至关重要。

以下是几种主要的本地存储技术,每种技术都适用于不同的使用场景:

  1. shared_preferences 是 Flutter 应用中实现轻量级数据持久化的标准解决方案。它主要用于存储小量的键值对数据,如用户设置或应用配置。这种方法以其简单易用和高效的性能特别适合管理简单的用户偏好

  2. sqflite,基于 SQLite 的存储方案,为 Flutter 应用提供了全功能的关系型数据库支持。它允许开发者执行 SQL 语句进行数据的增删改查操作,非常适合需要存储大量结构化数据的场景。sqflite 支持事务、批量操作和复杂查询,为数据持久化提供了强大的灵活性和扩展性。

  3. hive 以其出色的性能和直观的 API 而著称,是一个为 Dart 和 Flutter 专门设计的轻量级键值对数据库hive 支持存储复杂的数据结构,如列表和地图,且不需要事先定义模式。它特别适合需要快速读写操作的应用场景,并且可以在不同的 Flutter 平台上无缝工作。

  4. 文件存储 通过直接在设备文件系统上读写数据文件,提供了极高的灵活性。开发者可以使用 Dart 的 dart:io 库来操作文件,以存储和检索自定义格式的数据,如 JSON 文档、图片或其他二进制文件。这种方法适合于数据量大或数据结构复杂的场景,需要开发者手动管理文件的创建、读写和删除操作。

选择合适的本地存储方案需要综合考虑数据的类型、量级、访问频率以及特定平台的特性。shared_preferences 适用于轻量数据存储,sqflitehive 提供了更复杂的数据管理能力,而直接的 文件存储 则在处理大型或自定义数据时提供了最大的灵活性。

补充说明

为了帮助理解 Flutter 中的本地存储和数据缓存,我们将通过一个简单的实际案例演示如何使用 shared_preferences 来存储和检索用户设置。

实际案例

我们的目标是创建一个简单的 Flutter 应用,它允许用户通过开关控件开启或关闭某个功能,并且应用会记住用户的选择。即使应用关闭再重新打开,之前的设置也会被保留。

完整代码示例

首先,你需要在你的 pubspec.yaml 文件中添加 shared_preferences 包的依赖项:

dependencies:flutter:sdk: fluttershared_preferences: ^2.2.2

然后,下面是我们的 Flutter 应用代码:

import 'package:flutter/material.dart';
import 'package:shared_preferences/shared_preferences.dart';void main() => runApp(MyApp());class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: SettingsScreen(),);}
}class SettingsScreen extends StatefulWidget {_SettingsScreenState createState() => _SettingsScreenState();
}class _SettingsScreenState extends State<SettingsScreen> {bool _isFeatureEnabled = false;void initState() {super.initState();_loadSettings();}// 从 shared_preferences 加载设置_loadSettings() async {final prefs = await SharedPreferences.getInstance();setState(() {_isFeatureEnabled = prefs.getBool('featureEnabled') ?? false;});}// 更新设置并保存到 shared_preferences_updateSettings(bool newValue) async {final prefs = await SharedPreferences.getInstance();setState(() {_isFeatureEnabled = newValue;prefs.setBool('featureEnabled', _isFeatureEnabled);});}Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text('设置'),),body: SwitchListTile(title: Text('启用某功能'),value: _isFeatureEnabled,onChanged: _updateSettings,),);}
}

运行结果

当你运行这段代码时,你会看到一个包含开关控件的设置页面。用户可以通过开关控件来启用或禁用某个功能。当用户更改设置时,这个设置会被保存到 shared_preferences 中。因此,即使应用被关闭,当应用下次启动时,之前的设置也会被恢复。

image-20240320205647539

详细说明

  • 我们定义了一个 SettingsScreen StatefulWidget,因为我们需要管理设置的状态。
  • _loadSettings 方法中,我们使用 SharedPreferences.getInstance() 获取 SharedPreferences 的实例,然后通过 getBool 方法检索 'featureEnabled' 键对应的值。如果这个键不存在,我们假定该功能被禁用(即返回 false)。
  • _updateSettings 方法用于更新设置的状态,并通过 setBool 方法将新的设置值保存到 shared_preferences 中。

这个例子展示了如何使用 shared_preferences 在 Flutter 应用中进行简单的本地数据存储和检索,这对于管理用户偏好设置等轻量级数据非常有用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/760152.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【火猫TV】LPL春季赛前瞻:Tabe迎战LNG OMG关键一战!

北京时间3月20日&#xff0c;LPL春季赛今天继续进行&#xff0c;今天将会迎来春季赛常规赛第八周第三个比赛日&#xff0c;今天的两场比赛是LNG战队对阵AL战队以及OMG战队对阵BLG战队&#xff0c;今天的两场比赛对于LNG、AL以及OMG战队都是比较重要的&#xff0c;目前三支战队都…

第十二届蓝桥杯省赛CC++ 研究生组-货物摆放

还是整数分解问题,注意n本身也是约数 #include <iostream> int main(){printf("2430");return 0; }#include <iostream> #include<cmath> #include<algorithm> using namespace std; typedef long long ll; const ll n 2021041820210418LL…

QGIS开发笔记(一):QGIS介绍、软件下载和加载shp地图数据Demo

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/136888334 红胖子网络科技博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬…

实现安卓连接阿里云物联网平台(2)

完整工程链接 链接&#xff1a;https://pan.baidu.com/s/1ykcJHPBSKBXVMaMWKoVRvA?pwd8888 提取码&#xff1a;8888 &#xff08;1&#xff09;创建一个新工程 &#xff08;2&#xff09;添加mqtt包的依赖 implementation org.eclipse.paho:org.eclipse.paho.client.mqttv…

MINT: Detecting Fraudulent Behaviors from Time-series Relational Data论文阅读笔记

2. 问题定义 时间序列关系数据&#xff08;Time Series Relation Data&#xff09; 这个数据是存放在关系型数据库中&#xff0c;每一条记录都是泰永时间搓的行为。 更具体地&#xff0c;每条记录表示为 x ( v , t , x 1 , x 2 , … , x m − 2 ) x (v,t,x_1,x_2,\dots,x…

【Unity】UI九宫格

什么是九宫格&#xff1f; 顾名思义&#xff0c;九宫格就是指UI切成9个格子&#xff0c;9个格子可以任意拉伸。 1、3、7、9不拉伸。 2、8水平拉伸。 4、6垂直拉伸。 5既可以水平也可以垂直拉伸。 怎么切九宫格&#xff1f; 选中图片&#xff0c;改成Sprite模式&#xff0c;点…

[flask] flask的基本介绍、flask快速搭建项目并运行

笔记 Flask Flask 本身相当于一个内核&#xff0c;其他几乎所有的功能都要用到扩展&#xff08;邮件扩展Flask-Mail&#xff0c;用户认证Flask-Login&#xff0c;数据库Flask-SQLAlchemy&#xff09;&#xff0c;都需要用第三方的扩展来实现。比如可以用 Flask 扩展加入ORM、…

婴儿奶瓶哪个品牌最好?五大热门品牌深度测评推荐

最近很多新手爸妈都在后台私信咨询如何选购婴儿奶瓶&#xff0c;以及要怎么选才能够避雷避坑。为了解答大家的问题&#xff0c;我特地为大家对现在的各种主流款奶瓶进行全面测评。 对于婴儿奶瓶&#xff0c;可能有些新手爸妈觉得随便买买就好&#xff0c;但实际上挑选婴儿奶瓶…

day12-SpringBootWeb 登录认证

一、登录功能 Slf4j RestController public class LoginController {Autowiredprivate EmpService empService;PostMapping("/login")public Result login(RequestBody Emp emp){log.info("员工登录: {}", emp);Emp e empService.login(emp);//登录失败, …

负阻尼振荡器仿真模拟

负阻振荡器&#xff08;Negative resistance oscillator&#xff09;是利用负阻器件抵消回路中的正阻损耗&#xff0c;产生自激振荡的振荡器。由于负阻器件与回路仅有两端连接&#xff0c;故负阻振荡器又称为“二端振荡器”。 阻尼是指阻碍物体的相对运动、并把运动能量转化为…

NVIDIA 推出地球-2云平台,使用AI超级计算机的模拟技术,预测整个地球的气候变化

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

new mars3d.layer.GeoJsonLayer({的pupup配置参考

new mars3d.layer.GeoJsonLayer({的pupup配置可选项以及相关效果参考&#xff1a; 说明&#xff1a;popup按属性字段配置&#xff0c;可以是字符串模板或数组 1.popup仅配置{type}{name}等属性的的时候&#xff0c;指显示json文件内数据的type与name&#xff0c;效果如下 相关…

MyBatis核心配置文件:解锁数据之美的密码

MyBatis&#xff0c;这位编程的诗人&#xff0c;通过其独特的核心配置文件&#xff0c;为我们描绘出一幅数据之美的画卷。本篇博客将带你深入探讨MyBatis核心配置文件的奥秘&#xff0c;让你能够更好地理解和运用这个优雅的数据持久化框架。 最近想搞私域&#xff0c;欢迎各位…

【MySQL】8. 基本查询(update/delete/聚合/分组)

表的删改 3. Update 语法&#xff1a; UPDATE table_name SET column expr [, column expr ...] [WHERE ...] [ORDER BY ...] [LIMIT ...]对查询到的结果进行列值更新 案例&#xff1a; 3.1 将孙悟空同学的数学成绩变更为 80 分 -- 更新值为具体值 -- 查看原数据 SELECT…

开发指南-1:编码技巧与规范开始

目录 实例 1.使用对象代替if及switch 2.使用Array.from快速生成数组 3.使用router.beforeEach来处理跳转前逻辑 4.使用v-if来优化页面加载 5.路由跳转尽量使用name而不是path 6.使用key来优化v-for循环 7.使用computed代替watch 8.统一管理缓存变量 9.使用setTimeout…

【深度学习】训练Stable Diffusion环境

仓库&#xff1a; https://github.com/bmaltais/kohya_ss.git 基础镜像&#xff1a; from kevinchina/deeplearning:sdxllighting_trt_nginx_002api docker run --net host --gpus device0 -e APIWORKS1 -it t1:t1 bash构建环境&#xff1a; sudo -i git clone https://git…

springboot291校园疫情防控系统

校园疫情防控系统的设计与实现 摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统校园疫情防控信息管理难度…

Source Insight关于复制一段代码会自动添加空格或者Tab键的配置取消

Source Insight关于复制一段代码会自动添加空格或者Tab键的配置取消&#xff0c;这个情况在我们复制代码的时候对格式非常不友好&#xff0c;解决办法如下。 如下&#xff0c;我们可以设置相关配置&#xff1a; 设置完成后&#xff0c;然后再去复制&#xff0c;可以看到就没有相…

网络编程:包头分析

一、以太网头 以太网中封装了源mac地址以及目的mac地址&#xff0c;还有ip类型&#xff0c;以太网又称为mac头 0X0800 只接收发往本机的mac的ipv4类型的数据帧 0X0806 只接收发往本机的ARP类型的数据帧 0x8035 只接受发往本机的RARP类型的数据帧 0X0003 接收发往本机的MAC所…

十八、软考-系统架构设计师笔记-真题解析-2022年真题

软考-系统架构设计师-2022年上午选择题真题 考试时间 8:30 ~ 11:00 150分钟 1.云计算服务体系结构如下图所示&#xff0c;图中①、②、③分别与SaaS、PaaS、IaaS相对应&#xff0c;图中①、②、③应为( )。 A.应用层、基础设施层、平台层 B.应用层、平台层、基础设施层 C.平…