如何在 dart 函数中将函数作为可选参数传递并带有默认值?

Mid*_*lai 6 default-parameters dart

这就是我想要实现的:

void fun({
  bool Function(int i) predicate = (i) => false,
}) {
  // do something with 'predicate(something)'
}
Run Code Online (Sandbox Code Playgroud)

但我收到错误:

可选参数的默认值必须是constant.dart(non_constant_default_value)。

我能够通过以下方法解决此错误:

bool falsePredicate(int i) => false;

void fun({
  bool Function(int i) predicate = falsePredicate,
}) {
  // do something with 'predicate(something)'
}
Run Code Online (Sandbox Code Playgroud)

但现在问题来了,为什么我不能像第一组代码那样直接创建一个默认函数值呢?第一种情况和第二种情况似乎没有什么区别。第一种方法中给出的函数为什么不是常数?

Sis*_*sir 2

正如@Noah 指出的 git 讨论一样,dart 语言缺少编译时常量函数,这最终导致了这个问题。

检查这篇文章:https ://github.com/dart-lang/language/issues/1048

正如帖子所示,这个问题是在2012年中提出的,现在已经过去了8年多了。因此,在近期功能中提供此功能的希望非常渺茫。

然而,到目前为止,很少有替代解决方案:

选项 1(单独方法):

class ServiceProvider {
    static bool falsePredicate(int i) => false;
    
    void fun({
      bool Function(int i) predicate = falsePredicate,
    }) {
      // do something with 'predicate(something)'
    }
}
Run Code Online (Sandbox Code Playgroud)

选项 2(使用时进行 Null 检查predicate

class ServiceProvider {
    void fun({
      bool Function(int i)? predicate,
    }) {
        int val = 55; // for demonstration
        predicate?.call(val); // Call only if the predicate is non-null
    }
}
Run Code Online (Sandbox Code Playgroud)

选项 3(仅适用于类构造函数)

class ServiceProvider {
    final bool Function(int i) _predicate;
  
    ServiceProvider ({bool Function(int i)? predicate})
       : _predicate = predicate ?? ((i) => false);
  
    void fun() {
       int val = 55;
       _predicate(5); // No null check is needed. The predicate is always non-null
    }
}
Run Code Online (Sandbox Code Playgroud)