gpt4 book ai didi

flutter - 对小部件的 State 对象调用 setState()

转载 作者:行者123 更新时间:2023-12-03 03:33:17 24 4
gpt4 key购买 nike

flutter 下面的代码处理底部栏的管理,当代码执行时,点击 Icons.add 按钮,然后更改底部元素,系统显示以下错误:

错误:

[VERBOSE-2:ui_dart_state.cc(157)] Unhandled Exception: setState() called after dispose(): _HomeViewScreenState#d0762(lifecycle state: defunct, tickers: tracking 1 ticker)

如果您对不再出现在小部件树中的小部件的 State 对象调用 setState() ,则会发生此错误(例如,其父小部件不再在其构建中包含该小部件)。当代码从计时器或动画回调调用 setState() 时,可能会发生此错误。

首选的解决方案是在 dispose() 回调中取消计时器或停止监听动画。另一种解决方案是在调用 setState() 之前检查该对象的“mounted”属性,以确保该对象仍在树中。

如果调用 setState(),此错误可能表示内存泄漏,因为另一个对象在从树中删除后仍保留对此 State 对象的引用。为了避免内存泄漏,请考虑在 dispose() 期间中断对此对象的引用。

Flutter Code

Flutter Code HomeState

最佳答案

您需要检查小部件是否已安装。不要直接调用 setState,而是使用:

if (mounted)
setState(() {});

说明:当您离开屏幕时,小部件将被释放。所以你不能对其调用setState()

关于flutter - 对小部件的 State 对象调用 setState(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62550698/

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