cancel_subscriptions
Cancel instances of dart:async
StreamSubscription
.
此规则自 Dart 2.0 版本起可用。
详情
#DO invoke cancel
on instances of dart:async
StreamSubscription
.
Cancelling instances of StreamSubscription prevents memory leaks and unexpected behavior.
BAD:
dart
class A {
StreamSubscription _subscriptionA; // LINT
void init(Stream stream) {
_subscriptionA = stream.listen((_) {});
}
}
BAD:
dart
void someFunction() {
StreamSubscription _subscriptionF; // LINT
}
GOOD:
dart
class B {
StreamSubscription _subscriptionB; // OK
void init(Stream stream) {
_subscriptionB = stream.listen((_) {});
}
void dispose(filename) {
_subscriptionB.cancel();
}
}
GOOD:
dart
void someFunctionOK() {
StreamSubscription _subscriptionB; // OK
_subscriptionB.cancel();
}
Known limitations
This rule does not track all patterns of StreamSubscription instantiations and cancellations. See linter#317 for more information.
使用方法
#要启用 cancel_subscriptions
规则,请在你的 analysis_options.yaml
文件中,在 linter > rules 下添加 cancel_subscriptions
:
analysis_options.yaml
yaml
linter:
rules:
- cancel_subscriptions
除非另有说明,否则本网站上的文档反映的是 Dart 3.6.0。页面最后更新于 2025-02-05。 查看源代码 或 报告问题.