有关java-8
语法的简单问题。为什么JLS-8
限制这样的表达式:
Object of_ref = Stream::of; // compile-time error
并只允许以下内容:
java.util.function.Function of_ref = Stream::of;
Object obj = of_ref; // compiles ok
?
这是因为方法引用或lambda表达式的目标类型应该是功能接口。仅基于此,运行时将创建提供给定功能接口的实现的类的实例。将lambda或方法引用视为abstract
概念。将其分配给功能接口类型将赋予其具体含义。
此外,特定的lambda或方法引用可以具有多个功能接口作为其目标类型。例如,考虑以下lamda:
int x = 5;
FunctionalInterface func = (x) -> System.out.println(x);
这个lambda是Consumer
的x
。除此之外,任何具有单个抽象方法且具有以下签名的接口:
public abstract void xxx(int value);
可以用作目标类型。因此,如果您将lambda分配给Object
type
,那么您希望运行时实现哪个接口?这就是为什么您必须显式提供功能接口作为目标类型的原因。
现在,一旦获得包含实例的功能接口引用,就可以将其分配给任何超级引用(包括Object
)
问题内容: 我试图为对象类型分配一个lambda: 它给我一个错误的说法: 为什么会这样,怎么做? 问题答案: 这是不可能的。根据错误消息不是功能接口,即具有单个公共方法的接口,因此您需要使用引用类型,例如
我有以下代码 我已经阅读了(MSDN) 关键字<code>constexpr</code>在C 11中引入,并在C 14中进行了改进。它表示常量表达式。与<code>const</code>一样,它可以应用于变量,因此如果任何代码试图修改值,就会引发编译器错误。 阅读后,我认为可以使用代替,但是对于上面的代码,我收到一个编译器错误,指出 当 被 替换时,它可以正常工作。我不理解这种行为;有人能说出
问题内容: 以下语句: 因错误而失败: 为什么在这里需要演员表? 我发现了几篇文章,解释了为什么您不能进行反向操作(将T分配给a),但这是显而易见的(可以理解)。 注意:我在Eclipse Luna下对此进行编码,所以我不知道这是Luna Quirk还是泛型中确实不了解的东西。 问题答案: 协方差vs协方差vs不变性 是 不变的 。 结果是, 是 不是一个亚型 的 在Java中,变量可以保存 相同
问题内容: 抱歉,标题似乎令人困惑,但请按示例进行操作。 假设我有一些带有通用类型参数的Java类: 我可以创建一个类型为存储对象的变量,并将通用参数设置为。Java还允许我将该变量分配给另一个变量,但将通用参数设置为通配符类型: 但是,在使用具有泛型参数的类时,如果将该参数的类型设置为泛型,则无法将该类的对象分配给相同类型/泛型的类型,后者(内部/嵌套)参数是通配符类型: 具体的编译错误是: 凭
我刚刚更新到Dart2和Flatter sdk:' 无法将参数类型“Object”指定给参数类型“ImageProvider”。), 我只是从弗利特开始,不知道该去哪里找别的。
由于最近的更新,我正面临这个问题,请伙计们帮帮我