>  기사  >  Java  >  Java 8의 새로운 기능인 Lambda 표현식에 대한 간략한 분석

Java 8의 새로운 기능인 Lambda 표현식에 대한 간략한 분석

高洛峰
高洛峰원래의
2017-01-23 15:33:371591검색

Java 8에 대해 이야기할 때 가장 먼저 떠오르는 것은 람다(클로저)와 가상 확장 방법(기본 방법)입니다. 이 기능은 이미 주요 기술 웹사이트에서 과장된 기능이며, 우리도 이 기능을 가장 먼저 사용합니다. Java 8 시리즈의 시작 부분에서 설명할 예정입니다(JEP126 http://openjdk.java.net/jeps/126). jdk8의 일부 라이브러리는 람다 표현식을 사용하여 재설계되었습니다. 자바 8의 새로운 기능.

1. 기능적 인터페이스

기능적 인터페이스(기능적 인터페이스라고도 하는데 실제로는 같습니다). 간단히 말해서, 기능적 인터페이스는 하나의 메서드만 포함하는 인터페이스입니다. 예를 들어 Java 표준 라이브러리의 java.lang.Runnable 및 java.util.Comparator는 일반적인 기능 인터페이스입니다. Java 8은 @FunctionalInterface를 주석으로 제공합니다. 그러나 인터페이스가 기능적 인터페이스(즉, 하나의 메소드만 포함하는 인터페이스)를 충족하는 한 가상 머신은 이를 자동으로 결정합니다. 인터페이스에 @FunctionalInterface 주석을 사용하여 선언하는 것이 가장 좋습니다. 이렇게 하면 팀의 다른 사람이 실수로 인터페이스에 새 메서드를 추가하는 것을 방지할 수 있습니다.
Java에서 람다는 단독으로 나타날 수 없습니다. 람다 표현식 메서드 본문은 실제로 함수형 인터페이스의 구현입니다.

2. 람다 구문

세 부분으로 구성

1. 괄호 안에 쉼표로 구분된 형식 매개변수입니다. 매개변수는 기능적 인터페이스의 메소드 매개변수입니다.

2 . 화살표 기호:- >

3. 메소드 본문은 함수형 인터페이스의 메소드 구현입니다. {}로 래핑해야 하며 반환 값이 필요하지만, 기능적 인터페이스에서 메서드의 반환 값이 void인 경우에는 {}

필요하지 않습니다.

(parameters) -> expression 或者 (parameters) -> { statements; }

이해하기 쉽게 전체 예제를 살펴보세요

/**
 * 测试lambda表达式
 *
 * @author benhail
 */
public class TestLambda {
    public static void runThreadUseLambda() {
        //Runnable是一个函数接口,只包含了有个无参数的,返回void的run方法;
        //所以lambda表达式左边没有参数,右边也没有return,只是单纯的打印一句话
        new Thread(() ->System.out.println("lambda实现的线程")).start(); 
    }
    public static void runThreadUseInnerClass() {
        //这种方式就不多讲了,以前旧版本比较常见的做法
        new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println("内部类实现的线程");
            }
        }).start();
    }
    public static void main(String[] args) {
        TestLambda.runThreadUseLambda();
        TestLambda.runThreadUseInnerClass();
    }
}

람다 표현식을 사용하여 디자인한 코드가 더 간결하고 가독성이 높다는 것을 알 수 있습니다.

3. 메소드 참조

는 실제로 람다 표현식을 작성하는 간단한 방법입니다. 참조된 메소드는 실제로 람다 표현식의 메소드 본문 구현입니다. 컨테이너(can은 클래스 이름, 인스턴스 이름), 가운데는 "::"이고 오른쪽은 해당 메서드 이름입니다. 아래와 같이

ObjectReference::methodName

일반 메서드의 참조 형식은

정적 메서드인 경우 ClassName::methodName입니다. 예를 들어 Object::equals

인스턴스 메서드인 경우 Instance::methodName입니다. 예를 들어 Object obj=new Object();obj::equals;

생성자는 ClassName::new

입니다. 이해하기 쉽도록 전체 예를 살펴보겠습니다.

import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import javax.swing.JButton;
import javax.swing.JFrame;
/**
 *
 * @author benhail
 */
public class TestMethodReference {
    public static void main(String[] args) {
        JFrame frame = new JFrame();
        frame.setLayout(new FlowLayout());
        frame.setVisible(true);

        JButton button1 = new JButton("点我!");
        JButton button2 = new JButton("也点我!");

        frame.getContentPane().add(button1);
        frame.getContentPane().add(button2);
        //这里addActionListener方法的参数是ActionListener,是一个函数式接口
        //使用lambda表达式方式
        button1.addActionListener(e -> { System.out.println("这里是Lambda实现方式"); });
        //使用方法引用方式
        button2.addActionListener(TestMethodReference::doSomething);

    }
    /**
     * 这里是函数式接口ActionListener的实现方法
     * @param e 
     */
    public static void doSomething(ActionEvent e) {

        System.out.println("这里是方法引用实现方式");

    }
}

doSomething 메소드는 람다 표현식을 구현한 것임을 알 수 있습니다. 이것의 장점은 람다 메소드가 매우 길어 코드의 가독성에 영향을 미친다고 느낄 경우 메소드 참조가 해결책이라는 것입니다

4. 요약

위 내용은 람다 표현식 구문의 전체 내용입니다. 람다 표현식에 대해서는 누구나 어느 정도 이해하고 계시리라 믿습니다. 그러나 코드가 단순하면 많은 시청자에게 감동을 주지 못할 것입니다. Java 8도 마찬가지입니다. 사실 Java 8에서 람다 도입이 시급한 이유는 람다 표현식이 컬렉션에 대한 데이터의 멀티 스레드 또는 멀티 코어 처리를 단순화하고 더 빠른 컬렉션 처리 속도를 제공할 수 있기 때문입니다. 이에 대해서는 JEP126에서 나중에 다루겠습니다. 기능을 3개 부분으로 나누는 이유는 이 기능에 대해 작성할 수 있는 내용이 너무 많기 때문입니다. 이 부분을 통해 독자는 람다 표현식의 구문과 개념을 익힐 수 있습니다. 두 번째 부분은 가상 확장 방법(기본 방법)이고, 마지막 부분은 대규모 데이터 수집 처리에 대해 설명하며 람다 표현식의 가장 강력한 효과에 대한 미스터리를 풀어냅니다.

Java 8의 새로운 기능인 람다 표현식 분석과 관련된 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.