跳到主要内容

discarded_futures

稳定版
修复可用

不要在非 async 代码块中调用异步函数。

详情

#

在非 async 函数中进行异步调用通常是编程错误的迹象。一般来说,这些函数应该标记为 async,并且这些 Future 很可能应该被等待(正如 unawaited_futures 所强制执行的那样)。

不要在非 async 代码块中调用异步函数。

错误示例

dart
void recreateDir(String path) {
  deleteDir(path);
  createDir(path);
}

Future<void> deleteDir(String path) async {}

Future<void> createDir(String path) async {}

正确示例

dart
Future<void> recreateDir(String path) async {
  await deleteDir(path);
  await createDir(path);
}

Future<void> deleteDir(String path) async {}

Future<void> createDir(String path) async {}

启用

#

要启用 discarded_futures 规则,请在您的 analysis_options.yaml 文件中的 linter > rules 下添加 discarded_futures

analysis_options.yaml
yaml
linter:
  rules:
    - discarded_futures

如果您改为使用 YAML 映射语法来配置 linter 规则,请在 linter > rules 下添加 discarded_futures: true

analysis_options.yaml
yaml
linter:
  rules:
    discarded_futures: true