gpt4 book ai didi

android - Jetpack Compose 普通值和记住值之间的区别

转载 作者:行者123 更新时间:2023-12-03 07:49:52 26 4
gpt4 key购买 nike

如果我有一个被多个可组合项使用的不可变值,我应该怎么做赋值?哪个选项更有效。记住会给我带来性能提升吗?这是一个奇怪的问题,但我找不到任何相关示例。

我的想法:对于选项 1,在每次重组时,示例值将一遍又一遍地设置为 5.dp 我认为这是不必要的,因为它始终是 5.dp

对于选项 2,第一次重组时,示例值将设置为 5.dp,并且永远不会再次设置。我认为使用 Remember 更有效,但我不确定。

    @Composable
fun MyComposable() {
val example = 5.dp //option 1
val example = remember { 5.dp } //option 2

Box(modifier = Modifier
.height(example)
.padding(example)) {

Column {
Text(text = "example", modifier = Modifier.padding(example))
}
}
}

最佳答案

Does remember gives me performance gain ?

没有。

remember 不应该用作像这样的性能优化,因为它所做的内存通常是多余的,而 @Composable 函数已经做了这可能比你更多正在期待。

具体来说,由于 5.dp 只是一个伪装的浮点值,因此选项 1 更有效。

您永远不需要记住基元(或本例中的值类实例)。这只会消耗内存和时间。

...on every recomposition, example value will be set over and over to 5.dp

这不是真的。在这种情况下,只有初始组合才会调用 MyComposable 它不会再次被调用。这是因为 1) 它没有参数,所以它总是会跳过,2) 它没有观察到任何可变状态,所以它永远不会重新启动。

它总是会跳过,因为只要使用与上次调用时相同的参数调用可组合函数,它就会跳过。也就是说,可组合函数已经被内存,您不需要自己执行此操作。

如果可组合函数观察到可变状态已更改,它将重新启动。最简单的示例是读取已分配新值的 mutableStateOf() 结果。 Compose 将重新启动已读取已更改状态的可组合函数,以确定反射(reflect)更改的新组合应该是什么。

如果 MyComposable 被修改为具有参数或被修改为观察到的可变状态,则可以在重组期间调用它。即使这样,Compose 也会尝试通过检查修饰符是否生成与上次相同的修饰符来变得聪明。这允许 BoxText 跳过,因为它们的参数都没有改变。好吧,Box 不会跳过,因为它是内联函数,但内联的调用会跳过。

Compose 会记住合成的结果,并且只会执行合成中发生更改的部分。如果函数(如 MyComposable)的结果无法更改,则只会调用一次。如果它确实被调用但只是调用具有相同参数的可组合函数,它们将跳过,因此该函数将执行很少的操作。

关于android - Jetpack Compose 普通值和记住值之间的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/77466929/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com