Compose基础之State状态

Compose基础之State状态

    • Stateless和Stateful
      • 什么是Stateless,让我看下面代码
      • Stateless它有什么特点呢
      • Stateless它是如何实现避免无效重组的呢
      • 什么是Stateful,让我看下面代码
    • Compose中的State<T>
      • State子类之MutableState
    • 状态的恢复与持久化
      • remember
      • rememberSaveable
      • 其它方式:

Stateless和Stateful

什么是Stateless,让我看下面代码

@Composable
fun Greeting(name:String){Text(text = "Hello $name")
}

Greeting方法中未持有或访问了某些状态,它唯一变化的来自参数,所以他就是一个无状态的纯函数;

Stateless它有什么特点呢

1、当无状态函数的参数没有发生改变时,不会参与调用方的重组,将重组范围局限在无状态函数外部;

Stateless它是如何实现避免无效重组的呢

Compose编译器在@Composable注解的函数体内进行了字节码插桩技术,在Text调用之前对参数进行了判断,如果参数没有变化,则跳过对Text的调用,从而避免无效重组。

什么是Stateful,让我看下面代码

@Composable
fun GreetingStateful(){var name by remember{mutableStateOf("World")}Text(text = "Stateful")Text(text = "Hello $name", modifier = Modifier.clickable {name ="World ${Random.nextInt(100)}"})
}

在代码内部我们创建了状态name来记录最新的值,GreetingStateful中依赖对name的读写,因此它时一个Stateful。

Compose中的State

在Compose中使用State描述一个状态,当Composable对state的值进行读取的同时会与state建立订阅关系,当值发生改变时,Composable会自动重组刷新ui

@Stable
interface State<out T> {val value: T//不可修改
}

State子类之MutableState

如果需要对Sate的value进行修改,则需要使用MutableState来表示可修改状态

@Stable
interface MutableState<T> : State<T> {override var value: T //var可修改类型operator fun component1(): Toperator fun component2(): (T) -> Unit
}

创建方式1:直接赋值

    val name = mutableStateOf("default")

创建方式2:解构

	val(name2,setName2) = mutableStateOf("default")

创建方式3:属性代理

	var name3 by mutableStateOf("default")

状态的恢复与持久化

remember

1、未避免因重组导致状态的丢失,我们常见的是使用remember实现缓存状态

    var name4 by remember {mutableStateOf("default")}

rememberSaveable

2、虽然remember能跨越重组,但是不能跨越Acitivity和进程,这时我们需要使用rememberSaveable

    var name5 by rememberSaveable {mutableStateOf("default")}

rememberSaveable 中的数据会在onSaveInstanceState中以Bundle形式进行保存,在进程或者activity重建时根据key恢复到对应的Composable中,这个key是Compsable在编译期被确定的唯一表述,其源码如下

@Composable
fun <T : Any> rememberSaveable(vararg inputs: Any?,saver: Saver<T, out Any> = autoSaver(),key: String? = null,init: () -> T
): T {val compositeKey = currentCompositeKeyHash// key is the one provided by the user or the one generated by the compose runtimeval finalKey = if (!key.isNullOrEmpty()) {key} else {compositeKey.toString(MaxSupportedRadix)}@Suppress("UNCHECKED_CAST")(saver as Saver<T, Any>)val registry = LocalSaveableStateRegistry.currentval holder = remember {// value is restored using the registry or created via [init] lambdaval restored = registry?.consumeRestored(finalKey)?.let {saver.restore(it)}val finalValue = restored ?: init()SaveableHolder(saver, registry, finalKey, finalValue, inputs)}val value = holder.getValueIfInputsDidntChange(inputs) ?: init()SideEffect {holder.update(saver, registry, finalKey, value, inputs)}return value
}

其它方式:

如ViewModel等等方式,不再赘述

——note end——
原理有待探索~~

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

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

相关文章

Go-Gin-example 第五部分 加入swagger

上一节链接 swagger 为什么要用swagger 问题起源于 前后端分离&#xff0c; 后端&#xff1a;后端控制层&#xff0c;服务层&#xff0c;数据访问层【后端团队】前端&#xff1a;前端控制层&#xff0c;视图层&#xff0c;【前端团队】 所以产生问题&#xff1a;前后端联调…

Keepalived+LVS构建高可用集群

目录 一、Keepalive基础介绍 1. Keepalive与VRRP 2. VRRP相关技术 3. 工作原理 4. 模块 5. 架构 6. 安装 7. Keepalived 相关文件 7.1 配置组成 7.2 全局配置 7.3 VRRP实例配置&#xff08;lvs调度器&#xff09; 7.4 虚拟服务器与真实服务器配置 二、Keepalived…

HTML静态网页成品作业(HTML+CSS)——花主题介绍网页设计制作(1个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有1个页面。 二、作品演示 三、代…

C语言:基于单链表实现的泊车管理系统

一、需求 &#xff08;1&#xff09;管理员方账号登录&#xff1b; &#xff08;2&#xff09;车位管理显示&#xff1a;车位状态&#xff1b; &#xff08;3&#xff09;收费管理&#xff1a;小轿车 5元/小时&#xff0c;面包车6元/小时&#xff0c;大货车或客车7元/小时&a…

node.js 下 mysql2 的 CURD 功能极简封装

此封装适合于使用 SQL 直接操作数据库的小型后端项目&#xff0c;更多功能请查阅MySQL2官网 // 代码保存到单独的 js 文件const mysql require(mysql2/promise)const debug true let conn/*** 执行 SQL 语句* param {String} sql* param {*} params* returns {Array}*/ const…

ChatGPT提示技巧——零,一和少量示例提示

ChatGPT提示技巧——零&#xff0c;一和少量示例提示 ​ 零样本(zero-shot)、少样本(few-shot)和单样本(one-shot)提示是用于在最少或没有示例的情况下从ChatGPT生成文本的技巧。这些技巧用于当某个具体任务有限定数据的时候或者任务是新的并且没有很好的定义的时候。 提示格…

JVM的各种垃圾回收器(GC)

1. Serial GC Serial GC 是用于单线程环境的垃圾回收器&#xff0c;它使用复制算法&#xff08;Copy&#xff09;进行年轻代的垃圾回收&#xff0c;而老年代则使用标记-整理&#xff08;Mark-Compact&#xff09;算法。由于它在进行垃圾回收时会暂停其他所有的工作线程&#xf…

严密的逻辑会不会影响创新

严密的逻辑可以对创新产生积极的影响&#xff0c;也可能对创新产生负面的影响。以下是两种可能的情况&#xff1a; 积极影响&#xff1a;严密的逻辑可以帮助创新者更好地理解问题&#xff0c;并找到解决问题的方法。它可以帮助人们分析和评估不同的创新想法&#xff0c;以确定哪…

设计模式之——简单工厂模式

上图为简单工厂模式的架构图。 1&#xff0c;产品&#xff08;Product&#xff09; 将会对接口进行声明。 2&#xff0c;具体产品&#xff08;Concrete Products&#xff09;是产品接口的不同实现。 3&#xff0c;创建者&#xff08;Concrete Creators&#xff09;将会重写基…

二刷代码随想录算法训练营第十五天 |层序遍历 10、 226.翻转二叉树 、101.对称二叉树 2

目录 一、102. 二叉树的层序遍历 二、226. 翻转二叉树 三、101. 对称二叉树 一、102. 二叉树的层序遍历 题目链接&#xff1a;力扣 文章讲解&#xff1a;代码随想录 视频讲解&#xff1a; 讲透二叉树的层序遍历 | 广度优先搜索 | LeetCode&#xff1a;102.二叉树的层序遍历…

TCP传输收发

TCP通信: TCP发端: socket connect send recv close TCP收端: socket bind listen accept send recv close 1.connect int connect(int sockfd, const struct sockaddr *addr, socklen_t ad…

先缓存第二集抖音接入 ,最近加班猛,就分享简单的知识,如何使用:关于使用replace的用法正则表达式

1、需求&#xff1a;比如在cocos creator策划让你制作一个预制体&#xff0c;标题要读取配置&#xff0c;然后中间显示的内容要滚动的&#xff0c;要做成一个通用的&#xff0c;然后给到的配置表是这样子的: 配置表&#xff1a;假设字段是这样子的 content "内容标题&…

Intel 历代 CPU 型号

以下所有型号均为一整个系列&#xff0c;加上前缀、后缀啥的&#xff0c;差异化早在1970年代就被美国资本家玩明白了&#xff0c;充分地占领了市场。 CPU型号时间位数频率内存寻址地址总线说明400419714位740KHz640B4001(ROM)&#xff0c;4002(RAM)&#xff0c;4003(register)…

20个Python函数程序实例

前面介绍的函数太简单了&#xff1a; 以下是 20 个不同的 Python 函数实例 下面深入一点点&#xff1a; 以下是20个稍微深入一点的&#xff0c;使用Python语言定义并调用函数的示例程序&#xff1a; 20个函数实例 简单函数调用 def greet():print("Hello!")greet…

寻找最近的公共父视图

题目 求两个视图的最近公共父视图 暴力解法 采用的是两个 while 循环嵌套迭代来查询最近的公共父视图, 时间复杂度 O(n), 详见 Masonry 的实现&#xff1a; - (instancetype)mas_closestCommonSuperview:(MAS_VIEW *)view {MAS_VIEW *closestCommonSuperview nil;MAS_VIEW *…

css-vxe-form-item中输入框加自定义按钮(校验位置错误)

1.浮动错误效果 提示内容不对 2.不使用浮动&#xff0c;使用行内块元素 代码如下 <vxe-form-item title"yoyo:" field"assembleWorkNo" span"8"><template #default><vxe-input style"width:70%;display:inline-block;&quo…

NLP神器Transformers入门简单概述

在这篇博客中,我们将深入探索 🤗 Transformers —— 一个为 PyTorch、TensorFlow 和 JAX 设计的先进机器学习库。🤗 Transformers 提供了易于使用的 API 和工具,使得下载和训练前沿的预训练模型变得轻而易举。利用预训练模型不仅能减少计算成本和碳足迹,还能节省从头训练…

全天候购药系统(微信小程序+web后台管理)

PurchaseApplet 全天候购药系统&#xff08;微信小程序web后台管理&#xff09; 传统线下购药方式存在无法全天候向用户提供购药服务&#xff0c;无法随时提供诊疗服务等问题。为此&#xff0c;运用软件工程开发规范&#xff0c;充分调研建立需求模型&#xff0c;编写开发文档…

Java输入和输出处理

一、Java I/O 文件、内存、键盘--->程序--->文件、内存、控制台 二、文件 相关记录或放在一起的数据的集合 思考&#xff1a; Java程序如何访问文件属性&#xff1f; 解答&#xff1a; Java API:java.io.File类 三、File类 File类的常用方法 方法名称说明boole…

maven项目结构管理统一项目配置操作

一、maven分模块开发 Maven 分模块开发 1.先创建父工程&#xff0c;pom.xml文件中&#xff0c;打包方式为pom 2.然后里面有许多子工程 3.我要对父工程的maven对所有子工程进行操作 二、解读maven的结构 1.模块1 <groupId>org.TS</groupId><artifactId>TruthS…