96SEO 2026-02-20 08:23 10
Compose为Compose。

在了解State之前需要先对Compose及申明性编程式有个大概的了解。
State初体验好了#xff0c;在你有一定了解的基础上#xff0c;我们先来运行几个Demo#xff0c;初步了解为何…etpack
Compose为Compose。
在了解State之前需要先对Compose及申明性编程式有个大概的了解。
State初体验好了在你有一定了解的基础上我们先来运行几个Demo初步了解为何使用state。
这个例子主要是想通过点击按钮改变文案的显示。
这个过程称之为重组Demo1classStateDemoActivity
{overridefunonCreate(savedInstanceState:
{supportActionBar?.hide()super.onCreate(savedInstanceState)WindowCompat.setDecorFitsSystemWindows(window,
Modifier.fillMaxSize().systemBarsPadding())
value:false复制代码可以发现点击按钮Text显示的文本没有改变没有达到预想的目的。
Demo2这次我们使用官方的MutableStateTestComposeTheme
mutableStateOf(false)Log.e(StateDemoActivity,
value:${state.value})Column(modifier
Modifier.fillMaxSize().systemBarsPadding())
!state.valueLog.e(StateDemoActivity,
复制代码输出如下显示的文案依然没有改变但相比之前多了Column之前的打印这表明方法体被重新执行了state变量的哈希值也在变化。
以上表现和普通java方法别无区别state是方法中的局部变量。
StateDemoActivity
value:false复制代码Demo3这次我们稍作改动额外使用remember函数其他不变var
复制代码输出如下按钮文字终于如预想的那样发生了变化此外有个特别的现象是state变量的哈希值并没有发生变化表明方法每次执行时state变量并没有重新创建。
StateDemoActivity
value:false复制代码remember方法内部必然有全局容器存储变量源码中可以很明显的看出Composable
复制代码综上我们可以知道Compose是依赖对State变化的观察来重新执行Compose方法准确来说Compose基于参数的比较结果来决定是否重组重组与稳定类型接上文一个
函数在重组中被调用时如果参数与上次调用时相比没有发生变化则函数的执行会跳过重组提升重组性能。
需要特别说明Compose不会因为被观察的对象与上次是同一个就跳过重组。
详情参考
ImmutableComposable的重组范围在之前的内容中我们已经知道了参数的变化会影响重组是否执行这就带了重组范围的问题。
这方面大佬已经有了很好的文章。
建议小伙伴先阅读#
Compose理解composable的重组范围当我阅读后用代码验证时却发现了异常代码如下classStateDemoActivity
StateDemoActivity::class.java.simpleNameoverridefunonCreate(savedInstanceState:
{supportActionBar?.hide()super.onCreate(savedInstanceState)WindowCompat.setDecorFitsSystemWindows(window,
{mutableStateOf(0)}Column(modifier
Modifier.fillMaxSize().systemBarsPadding())
这行是不应该被打印出来的即不应该参与重组的可实际结果却相反。
小伙伴可以自己思考下稍后再往下翻看原因--------------完美的分割线^_^------------classStateDemoActivity
StateDemoActivity::class.java.simpleName}....
复制代码日志终于和理解的一样了现在我们回头找原因知道问题就出在打印的变量“TAG”身上。
方法中各作用域Scope都读取了变量“TAG”在第一个代码中该变量是个非稳定类型故按钮触发重组时为了保证正确性所有引用到该变量的Scope都会重组而第二个代码中“TAG”已经是个静态变量了故而是个稳定类型所以重组时不会引发非必要的重组。
最后补充一点从Android
View转Compose过程中对LiveData的使用场景需要特别留意。
因为原本对LiveData的观察是通过observe方法进行的每次LiveData内容更新即使值一样回调依然会收到转换为State之后只有value变化了才会引发重组例如val
viewModel.missOut.observeAsState(false).value
true,state只有在第一次设置为true时引发重组。
如果希望行为和之前observe一样应该如下调用LaunchedEffect(key1
{viewModel.missOut.asFlow().collect
复制代码Android核心知识点笔记Android开发核心知识点笔记Android
Framework核心知识点笔记音视频开发笔记入门到高级进阶Android
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback