JDK8이 나온지 꽤 됐습니다. 처음 나왔을 때 조금 알고 있다가 버리고, 이제 다시 집어들고 있어요. 지금은 JDK11이지만.
이 글은 계속 업데이트됩니다.
코드를 직접 보면 java8의 새로운 기능에서는 다음과 같이 작성할 수 있습니다.
public static void main(String[] args) { Supplier<Integer> supplier = ()->1; Consumer<String> consumer = (a)-> System.out.println(a); System.out.println(supplier.get()); consumer.accept("test"); }
출력:
1 test Process finished with exit code 0
매우 멋집니다. 이렇게 간결한 코드를 할 수 있겠습니까? java7
먼저 그림을 훔쳐서 Lambda를 설명하세요
즉, Lambda 표현식,해당 인터페이스의 구현을 생성한 다음 값을 할당할 때 변수에, 컴파일러를 사용하시나요? 다음과 같이 컴파일된 코드를 확인합니다.
public static void main(String[] args) { Supplier<Integer> supplier = () -> { return 1; }; Consumer<String> consumer = (a) -> { System.out.println(a); }; System.out.println(supplier.get()); consumer.accept("test"); }
컴파일러는 이 기능을 수행하지 않으므로 JVM이 Lambda 기능을 구현하는 것일 수 있습니다. 이에 대해서는 나중에 자세히 알아보겠습니다. Mark 1
여기서 작성하면 Lambda 표현식이 코드 양을 줄여준다는 것을 알 수 있습니다. Java8 이전에는 익명의 내부 클래스만 사용하거나 이 기능을 달성하기 위한 인터페이스를 구현하는 클래스를 생성할 수 있었습니다. 다음과 같습니다
Supplier<Integer> supplier = new Supplier<Integer>() { @Override public Integer get() { return 1; } };
사실 람다와 함께 제공되는 인터페이스가 더 궁금합니다. 소스코드를 열어보면 알 수 있습니다
@FunctionalInterface public interface Supplier<T> { /** * Gets a result. * * @return a result */ T get(); }
对应的接口都添加了注解FunctionalInterface,那么不要这个注解是否能实现Lambda表达式,我做了一些测试,发现不需要注解也可以实现,目前来看注解只有两个功能 1、表示这个接口是函数式接口 2、帮助编译器识别,接口不能有多个方法。 在有多个方法的时候会提示Multiple non-overriding abstract methods found in interface
이제 FunctionalInterface를 사용하여 JDK8에서 어떤 인터페이스가 기능적 인터페이스인지 알아볼 수 있습니다
그중에서 하나를 선택하세요. 가장 인기 있는 것 중 두 개가 테스트하고 배우기 위해 여기에 있습니다
아, 방금 기사를 읽고 매우 중요한 단락을 보았다는 말로 중단하겠습니다(실제로 기능적 인터페이스는 매우 취약합니다. 개발자가 인터페이스에 함수를 추가하면 인터페이스는 더 이상 함수형 인터페이스가 아니며 컴파일 오류가 발생합니다. 코드 수준에서 이러한 취약성을 극복하고 인터페이스가 함수형 인터페이스임을 명시적으로 나타내기 위해 Java 8에서는 특수한 인터페이스를 제공합니다. annotation)
저는 ArrayList와 Optional 두 클래스를 선택했는데 둘 다 매우 일반적으로 사용되는 클래스입니다.
관련 기사:
관련 동영상:
위 내용은 Java의 Lambda 표현식을 이해하고 테스트하고 학습해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!