gif*_*pif 90 java interface java-8
在Collection Interface中,我找到了一个removeIf()包含其实现的名为的方法.
default boolean removeIf(Predicate<? super E> filter) {
Objects.requireNonNull(filter);
boolean removed = false;
final Iterator<E> each = iterator();
while (each.hasNext()) {
if (filter.test(each.next())) {
each.remove();
removed = true;
}
}
return removed;
}
Run Code Online (Sandbox Code Playgroud)
我想知道是否有任何方法可以在接口中定义方法体?
什么是default关键字,它是如何工作的?
gif*_*pif 162
Java 8引入了"默认方法"或(Defender方法)新功能,它允许开发人员在不破坏这些接口的现有实现的情况下向接口添加新方法.它提供了允许接口定义实现的灵活性,在具体类无法为该方法提供实现的情况下,该实现将默认使用.
public interface A {
default void foo(){
System.out.println("Calling A.foo()");
}
}
public class ClassAB implements A {
}
Run Code Online (Sandbox Code Playgroud)
当人们第一次听到新功能时,有一个常见问题是人们会询问默认方法:
如果该类实现了两个接口并且这两个接口都定义了具有相同签名的默认方法,该怎么办?
举例来说明这种情况:
public interface A {
default void foo(){
System.out.println("Calling A.foo()");
}
}
public interface B {
default void foo(){
System.out.println("Calling B.foo()");
}
}
public class ClassAB implements A, B {
}
Run Code Online (Sandbox Code Playgroud)
此代码无法使用以下结果进行编译:
java: class Clazz inherits unrelated defaults for foo() from types A and B
Run Code Online (Sandbox Code Playgroud)
要解决这个问题,在Clazz中,我们必须通过覆盖冲突的方法来手动解决它:
public class Clazz implements A, B {
public void foo(){}
}
Run Code Online (Sandbox Code Playgroud)
但是如果我们想从接口A调用方法foo()的默认实现而不是实现我们自己的方法呢.
可以如下引用A#foo():
public class Clazz implements A, B {
public void foo(){
A.super.foo();
}
}
Run Code Online (Sandbox Code Playgroud)
Roh*_*ain 49
这些方法称为默认方法.默认方法或Defender方法是Java 8中新增的功能之一.
它们将用于允许接口方法在具体类不提供该方法的实现的情况下提供用作缺省的实现.
所以,如果你有一个接口,使用默认方法:
public interface Hello {
default void sayHello() {
System.out.println("Hello");
}
}
Run Code Online (Sandbox Code Playgroud)
以下类完全有效:
public class HelloImpl implements Hello {
}
Run Code Online (Sandbox Code Playgroud)
如果您创建一个实例HelloImpl:
Hello hello = new HelloImpl();
hello.sayHello(); // This will invoke the default method in interface
Run Code Online (Sandbox Code Playgroud)
有用的链接:
Ani*_*kur 17
我做了一些研究,我发现了以下内容.希望这可以帮助.
存在问题
普通接口方法声明为抽象,必须在实现接口的类中定义.这会给班级实施者带来"负担",他们有责任实施所有宣称的方法.更重要的是,这也意味着在"发布"之后无法扩展接口.否则,所有实施者都必须调整其实现,打破后向源和二进制兼容性.
Java 8中采用的解决方案
为了解决这些问题,JDK 8的一个新功能是可以使用默认方法扩展现有接口.默认方法不仅被声明,而且还在接口中定义.
重点要注意