news 2026/5/14 19:43:17

【Android】【Compose】Compose知识点复习(二)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Android】【Compose】Compose知识点复习(二)
可观察状态
状态类型与核心特点对照表
状态类型核心特点典型场景
mutableStateOf基础单值可观察状态,修改value触发重组计数器、开关、输入框文本、按钮状态
mutableStateListOf列表元素变化触发重组购物车、待办清单、动态列表
mutableStateMapOfMap 键值对变化触发重组用户配置、筛选条件、键值对数据
StateFlow + collectAsState跨组件共享状态,支持异步页面级共享状态、异步数据更新
derivedStateOf派生计算,仅结果变化触发重组(性能优化)滚动阈值、多状态组合计算
Flow + collectAsState普通 Flow 转可观察状态单次异步请求(网络/数据库)
remember ()

remember() 是 Compose 的 “状态存储器”,作用是在组件重组时保留状态值,避免每次重组都重新创建状态(比如mutableStateOf)。

通俗理解

把 Compose 重组比作 “教室换座位”:

没有remember():每次换座位,你都把笔记本扔了,重新拿个新本(mutableStateOf(0)重新创建,值重置为 0);

有remember():换座位时把笔记本装在书包里带走(状态被保留,值不会重置);

注意:remember() 只在 “同一重组作用域” 内有效 —— 如果组件被销毁重建(比如页面跳转后返回),状态还是会丢失(此时需要用rememberSaveable,但核心是remember的 “记忆” 特性)。

踩坑提醒:一定要加 remember!

如果忘记加remember(),会出现 “点击加 1 后,一重组就变回 0” 的诡异问题:

@ComposablefunRememberPitfallDemo(){// 错误:无remember,每次重组都重置为0val noRememberState=mutableStateOf(0)// 正确:有remember,重组时保留值val rememberState=remember{mutableStateOf(0)}Column{Text("无remember:${noRememberState.value}")// 永远是0(重组就重置)Text("有remember:${rememberState.value}")// 保留当前值Button(onClick={noRememberState.value++rememberState.value++}){Text("点击加1")}}}

日常开发中,remember和mutableStateOf几乎是 “绑定使用” 的:

// 标准写法:创建可观察状态并保留varcount by remember{mutableStateOf(0)}
= vs by
写法变量类型读取方式修改方式本质适用场景
val state = remember { mutableStateOf(0) }MutableState<Int>(容器)state.valuestate.value++直接持有状态容器本身需要操作容器(传递/比较)
var count by remember { mutableStateOf(0) }Int(容器内的值)countcount++通过委托访问容器内的值简化语法,直接操作值
通俗理解

把MutableState比作 “带盖子的盒子”:

= 写法:你直接拿到了 “整个盒子”,要拿 / 放里面的东西,必须先打开盖子(.value);

by 写法:你委托别人帮你管盒子,不用碰盒子本身,直接拿 / 放里面的东西(编译器自动开盖子)。

by 是 Kotlin 的委托语法糖,Compose 给MutableState实现了ReadWriteProperty接口,编译器会自动帮你补全.value:

// by 写法的等价代码(编译器自动生成)val countDelegate=remember{mutableStateOf(0)}varcount:Intget()=countDelegate.value// 读取时自动加.valueset(value){countDelegate.value=value}// 修改时自动加.value
注意点

by 写法必须用var(因为要修改值),用val会编译报错;

= 写法建议用val(容器本身不用重新赋值,只改内部.value);

两种写法的重组效果完全一致,没有性能差异,仅语法不同。

无状态 + 状态提升 + 单向数据流
概念核心定义
无状态组件组件内部不持有状态,所有状态由外部传入,仅负责“展示 UI”和“转发事件”
状态提升将组件的内部状态“提到”父组件管理,子组件通过参数接收状态和回调函数
单向数据流状态只能“从父到子”传递(读),修改需通过子组件调用父组件回调(写),形成闭环
通俗理解:用 “餐厅点餐” 类比

无状态组件 = 服务员:不记顾客点了什么(不持有状态),只负责把点餐需求传给前台(父组件),把菜品端给顾客(展示 UI);

状态提升 = 点餐状态交给前台:服务员(子组件)不存菜单,所有点餐信息集中在前台(父组件),避免多个服务员记的菜单不一致;

单向数据流 = 点餐流程:顾客→服务员→前台→后厨(状态传递:父→子),后厨做好菜→前台→服务员→顾客(事件回调:子→父),全程单向,不混乱。

反例 vs 正确示例
反例(有状态组件,不推荐)

子组件自己持有状态,父组件无法控制,复用性差:

// 有状态子组件:内部持有count,父组件无法获取/修改@ComposablefunBadCounter(){varcount by remember{mutableStateOf(0)}Button(onClick={count++}){Text("计数:$count")}}
正确示例(无状态 + 状态提升 + 单向数据流)
// 1. 无状态子组件:只接收状态和回调,不持有状态@ComposablefunGoodCounter(count:Int,// 从父组件接收状态(读)onCountAdd:()->Unit// 从父组件接收回调(写)){Button(onClick=onCountAdd){Text("计数:$count")}}// 2. 父组件:管理状态,实现单向数据流@ComposablefunCounterParent(){varcount by remember{mutableStateOf(0)}// 父组件持有状态Column{// 状态从父到子(读),修改通过回调(写)→ 单向数据流GoodCounter(count=count,onCountAdd={count++})Text("父组件同步显示:$count")// 父组件可复用状态,灵活扩展}}
核心优势

无状态组件:可复用性强(同一个组件传入不同状态就能展示不同内容)、易测试(传固定状态即可验证 UI);

状态提升:状态集中管理,避免多个组件持有同一份状态导致数据不一致;

单向数据流:状态变化可追踪,所有修改都通过回调函数,调试时能快速找到 “谁改了状态”。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 1:46:51

农业气象数据从哪来?小型农业气象站6要素实时监测,为农事安排添参考

农业生产与天气变化息息相关&#xff0c;霜冻、大风、暴雨等天气可能对作物造成直接影响。依赖大范围的公共天气预报&#xff0c;有时难以满足对特定小气候环境精准了解的需求。如何便捷地获取田间局地的气象信息&#xff0c;成为一些种植户关心的问题。小型农业气象站正是部署…

作者头像 李华
网站建设 2026/5/14 8:07:05

用Wan2.2-T2V-A14B实现720P高保真视频生成

用Wan2.2-T2V-A14B实现720P高保真视频生成 你有没有试过&#xff0c;在脑海中构思一个画面&#xff1a;阳光斜照的古风庭院里&#xff0c;一位身着汉服的女孩轻抚古琴&#xff0c;竹影随风摇曳&#xff0c;衣袖微扬&#xff0c;连琴弦的震颤都清晰可辨&#xff1f;过去&#xf…

作者头像 李华
网站建设 2026/5/9 0:29:05

大型语言模型(LLM)架构全面对比:从GPT到DeepSeek的技术演进与最佳实践

本文全面对比了2025年最新的大型语言模型架构&#xff0c;包括DeepSeek V3/R1、LLaMA 4、Gemma 3、Qwen3等主流模型。分析了它们在注意力机制(MLA、GQA、滑动窗口等)、归一化策略(Pre-Norm、Post-Norm、QK-Norm)、专家系统(MoE)以及效率优化技术(如线性注意力、NoPE)等方面的创…

作者头像 李华
网站建设 2026/5/12 9:12:05

个人阅读笔记:从年度开源工具榜单,我看到的三个技术趋势

阅读篇目&#xff1a;《2025 年度十大热门开源软件工具》 文章来源&#xff1a;科技区角 原文链接&#xff1a;https://www.x-techcon.com/article/84665.html 今天在「科技区角」读到了一篇高质量的年度盘点——《2025 年度十大热门开源软件工具》。文章不仅罗列了从数据湖&a…

作者头像 李华
网站建设 2026/5/12 3:53:09

告别闭源依赖!使用LobeChat搭建完全自主的AI对话系统

告别闭源依赖&#xff01;使用LobeChat搭建完全自主的AI对话系统 在企业开始将大模型深度融入业务流程的今天&#xff0c;一个现实问题正变得愈发棘手&#xff1a;我们是否真的愿意把所有客户咨询、内部知识甚至战略讨论&#xff0c;都通过API发送到第三方服务器上&#xff1f;…

作者头像 李华