목차
1. 동작 매개변수화
간결하고 전이적인 익명 함수
하나의 추상 메서드
jdk自带的函数式接口
使用过程中需要注意的一些事情
四. 方法引用
Java java지도 시간 Java 8의 새로운 기능: 람다 표현식

Java 8의 새로운 기능: 람다 표현식

Feb 23, 2017 am 10:34 AM
java8 lambda 새로운 특성

요약: 람다 표현식은 Java8이 제공하는 몇 가지 중요한 새 기능 중 하나입니다. 람다 표현식을 빌리면 Java 프로그램 디자인을 더욱 간결하게 만들 수 있습니다. 이 기사는 Java 8의 첫 번째 새로운 기능이며 동작 매개변수화, 람다 표현식 및 메소드 참조에 대해 설명합니다.

람다 표현식은 java8이 제공하는 몇 가지 중요한 새 기능 중 하나입니다. 람다 표현식을 빌리면 Java 프로그램 디자인을 더욱 간결하게 만들 수 있습니다. 최근 새로운 프로젝트는 버전 1.6을 포기하고 Java8을 기반으로 완전히 개발되었습니다. 이 기사는 Java8의 새로운 기능에 대한 첫 번째 기사이며 동작 매개변수화, 람다 표현식 및 메소드 참조에 대해 논의합니다.

1. 동작 매개변수화

동작 매개변수화는 단순히 함수의 본체에 템플릿 클래스 일반 코드만 포함되고 일부는 비즈니스 시나리오에 따라 변경된다는 의미입니다. 매개변수 형태로 함수에 전달됩니다. 동작 매개변수화를 사용하면 프로그램이 잦은 변경에 더 잘 대처할 수 있습니다.

프로그램을 통해 사과를 필터링해야 한다고 가정해 보겠습니다. 먼저 Apple 엔터티를 정의합니다.

/**
 * 苹果实体
 *
 * @author zhenchao.wang 2016-09-17 12:49
 * @version 1.0.0
 */
public class Apple {
    /** 编号 */
    private long id;
    /** 颜色 */
    private Color color;
    /** 重量 */
    private float weight;
    /** 产地 */
    private String origin;
    public Apple() {
    }
    public Apple(long id, Color color, float weight, String origin) {
        this.id = id;
        this.color = color;
        this.weight = weight;
        this.origin = origin;
    }
    // 省略getter和setter
}
로그인 후 복사

사용자의 초기 요구 사항은 간단할 수 있습니다. 프로그램을 통해 녹색 사과를 걸러낼 수 있으므로 프로그램을 통해 빠르게 달성할 수 있습니다.

/**
 * 筛选绿苹果
 *
 * @param apples
 * @return
 */
public static List<Apple> filterGreenApples(List<Apple> apples) {
    List<Apple> filterApples = new ArrayList<>();
    for (final Apple apple : apples) {
        if (Color.GREEN.equals(apple.getColor())) {
            filterApples.add(apple);
        }
    }
    return filterApples;
}
로그인 후 복사

잠시 후 사용자가 새로운 요구 사항을 제시하면 프로그램을 사용하여 빨간 사과를 필터링할 수 있으므로 특별히 빨간 사과를 필터링하는 기능을 추가했습니다.

/**
 * 筛选红苹果
 *
 * @param apples
 * @return
 */
public static List<Apple> filterRedApples(List<Apple> apples) {
    List<Apple> filterApples = new ArrayList<>();
    for (final Apple apple : apples) {
        if (Color.RED.equals(apple.getColor())) {
            filterApples.add(apple);
        }
    }
    return filterApples;
}
로그인 후 복사

더 나은 구현은 색상을 매개변수로 함수에 전달하는 것입니다. , 향후 사용자의 다양한 색상 필터링 요청을 처리할 수 있도록:

/**
 * 自定义筛选颜色
 *
 * @param apples
 * @param color
 * @return
 */
public static List<Apple> filterApplesByColor(List<Apple> apples, Color color) {
    List<Apple> filterApples = new ArrayList<>();
    for (final Apple apple : apples) {
        if (color.equals(apple.getColor())) {
            filterApples.add(apple);
        }
    }
    return filterApples;
}
로그인 후 복사

이렇게 디자인하면 더 이상 사용자의 색상 필터링 요구 사항 변경에 대해 걱정할 필요가 없습니다. 그런데 안타깝게도 어느 날 사용자가 무게가 특정 기준에 도달하는 사과를 선택할 수 있어야 한다는 요구사항을 요청했습니다. 이전 강의에서는 무게 기준도 선별 기능에 매개변수로 전달하여 다음과 같은 결과를 얻었습니다. >

/**
 * 筛选指定颜色,且重要符合要求
 *
 * @param apples
 * @param color
 * @param weight
 * @return
 */
public static List<Apple> filterApplesByColorAndWeight(List<Apple> apples, Color color, float weight) {
    List<Apple> filterApples = new ArrayList<>();
    for (final Apple apple : apples) {
        if (color.equals(apple.getColor()) && apple.getWeight() >= weight) {
            filterApples.add(apple);
        }
    }
    return filterApples;
}
로그인 후 복사

이것이 정말 매개변수를 전달하는 좋은 방법인가요? 필터링 조건이 점점 더 많아지고 조합 모드가 더욱 복잡해지면 모든 상황을 고려하고 각 상황에 맞는 전략을 세워야 할까요? 그리고 이러한 기능은 필터링 조건의 일부에서만 다를 뿐입니다. 동일한 템플릿 코드(컬렉션을 순회), 이때

동작을 매개변수화하여 함수가 템플릿 코드만 유지하고 필터링 조건을 추출하여 매개변수로 전달하도록 할 수 있습니다. 우리는 필터 인터페이스를 정의하여 이를 구현했습니다:

/**
 * 苹果过滤接口
 *
 * @author zhenchao.wang 2016-09-17 14:21
 * @version 1.0.0
 */
@FunctionalInterface
public interface AppleFilter {
    /**
     * 筛选条件抽象
     *
     * @param apple
     * @return
     */
    boolean accept(Apple apple);
}
/**
 * 将筛选条件封装成接口
 *
 * @param apples
 * @param filter
 * @return
 */
public static List<Apple> filterApplesByAppleFilter(List<Apple> apples, AppleFilter filter) {
    List<Apple> filterApples = new ArrayList<>();
    for (final Apple apple : apples) {
        if (filter.accept(apple)) {
            filterApples.add(apple);
        }
    }
    return filterApples;
}
로그인 후 복사

위 동작을 추상화한 후 특정 호출 위치에서 필터링 조건을 설정하고 메서드에서 조건을 매개 변수로 전달할 수 있습니다. 🎜>


public static void main(String[] args) {
    List<Apple> apples = new ArrayList<>();
    // 筛选苹果
    List<Apple> filterApples = filterApplesByAppleFilter(apples, new AppleFilter() {
        @Override
        public boolean accept(Apple apple) {
            // 筛选重量大于100g的红苹果
            return Color.RED.equals(apple.getColor()) && apple.getWeight() > 100;
        }
    });
}
로그인 후 복사

위의 동작 매개변수화 방법은 익명 클래스로 구현됩니다. 이 디자인은

java.util.Comparator
로그인 후 복사

,

java.util.concurrent.Callable
로그인 후 복사
<와 같이 jdk 내에서도 자주 사용됩니다. 🎜> 등 이러한 유형의 인터페이스를 사용할 때 익명 클래스를 사용하여 특정 호출 위치에서 함수의 특정 실행 논리를 지정할 수 있습니다. 그러나 위의 코드 블록으로 판단하면 매우 고객적이지만 간결하지는 않습니다. 충분히, java8에서는 람다를 통해 단순화할 수 있습니다:

// 筛选苹果
List<Apple> filterApples = filterApplesByAppleFilter(apples,
        (Apple apple) -> Color.RED.equals(apple.getColor()) && apple.getWeight() >= 100);
로그인 후 복사

람다 표현식을 통해 코드가 크게 단순화되었습니다. 자바의 람다 표현을 배워봅시다~


2. 람다 표현식 정의

람다 표현식을

간결하고 전이적인 익명 함수

로 정의할 수 있습니다. 먼저 람다 표현식이 본질적으로 함수라는 점을 분명히 해야 합니다. 특정 클래스에 속하지 않으며 매개변수 목록, 함수 본문, 반환 유형 및 예외 발생 기능이 있습니다. 둘째, 익명이며 람다 표현식에는 특정 함수 이름이 없습니다. 매개변수처럼 전달될 수 있습니다. , 따라서 코드 작성이 크게 단순화됩니다. 형식은 다음과 같이 정의됩니다.

형식 1: 매개변수 목록-> 표현식형식 2: 매개변수 목록-> {표현식 세트}
람다 표현식은 return 키워드를 암시한다는 점에 유의하세요. 이므로 단일 표현식에서는 return 키워드를 명시적으로 작성할 필요가 없지만 표현식이 명령문 모음인 경우 명시적으로 return을 추가하고 중괄호

{ }
로그인 후 복사

를 사용해야 합니다. 여기에서는 여러 표현식을 둘러싸야 합니다. 몇 가지 예는 다음과 같습니다.

//返回给定字符串的长度,隐含return语句
(String s) -> s.length() 
// 始终返回42的无参方法
() -> 42 
// 包含多行表达式,则用花括号括起来
(int x, int y) -> {
    int z = x * y;
    return x + z;
}
로그인 후 복사

3. 함수형 인터페이스에 의존하여 람다 식 사용

람다 식 사용 요구 사항 즉, 함수형 인터페이스의 도움으로 , 기능적 인터페이스가 나타나는 경우에만 람다 식을 사용하여 단순화할 수 있습니다.


사용자 정의 기능 인터페이스

기능 인터페이스는

하나의 추상 메서드

만 있는 인터페이스로 정의됩니다. Java 8의 인터페이스 정의 개선은 기본 메소드의 도입으로, 이를 통해 인터페이스의 메소드에 대한 기본 구현을 제공할 수 있습니다. 그러나 기본 메소드가 아무리 많아도 추상 메소드가 하나만 있으면 됩니다. , 다음과 같이(위의 AppleFilter 인용):

/**
 * 苹果过滤接口
 *
 * @author zhenchao.wang 2016-09-17 14:21
 * @version 1.0.0
 */
@FunctionalInterface
public interface AppleFilter {
    /**
     * 筛选条件抽象
     *
     * @param apple
     * @return
     */
    boolean accept(Apple apple);
}
로그인 후 복사
AppleFilter
로그인 후 복사
로그인 후 복사

에는 정의에 따라 하나의 추상 메소드
accept(Apple apple)
로그인 후 복사

만 포함됩니다. 이를 정의할 때 이 인터페이스에

를 추가했습니다.

@FunctionalInterface
로그인 후 복사

注解,用于标记该接口是函数式接口,不过这个接口是可选的,当添加了该接口之后,编译器就限制了该接口只允许有一个抽象方法,否则报错,所以推荐为函数式接口添加该注解。

jdk自带的函数式接口

jdk为lambda表达式已经内置了丰富的函数式接口,如下表所示(仅列出部分):




函数式接口函数描述符原始类型特化
Predicate<T>T -> booleanIntPredicate, LongPredicate, DoublePredicate
Consumer<T>T -> voidIntConsumer, LongConsumer, DoubleConsumer
FuncationT -> RIntFuncation, IntToDoubleFunction, IntToLongFunction, LongFuncation…
Supplier() -> TBooleanSupplier, IntSupplier, LongSupplier, DoubleSupplier
UnaryOperatorT -> TIntUnaryOperator, LongUnaryOperator, DoubleUnaryOperator
BinaryOperator(T, T) -> TIntBinaryOperator, LongBinaryOperator, DoubleBinaryOperator
BiPredicate(L, R) -> boolean
BiConsumer(T, U) -> void
BiFunction(T, U) -> R

下面分别就

Predicate<T>
로그인 후 복사

Consumer<T>
로그인 후 복사

Function<T, R>
로그인 후 복사

的使用示例说明。

Predicate<T>

@FunctionalInterface
public interface Predicate<T> {
    /**
     * Evaluates this predicate on the given argument.
     *
     * @param t the input argument
     * @return {@code true} if the input argument matches the predicate,
     * otherwise {@code false}
     */
    boolean test(T t);
}
로그인 후 복사

Predicate的功能类似于上面的

AppleFilter
로그인 후 복사
로그인 후 복사

,利用我们在外部设定的条件对于传入的参数进行校验,并返回验证结果

boolean
로그인 후 복사

,下面利用

Predicate
로그인 후 복사

对List集合的元素进行过滤:

/**
 * 按照指定的条件对集合元素进行过滤
 *
 * @param list
 * @param predicate
 * @param 
 * @return
 */
public  List filter(List list, Predicate<T> predicate) {
    List newList = new ArrayList();
    for (final T t : list) {
        if (predicate.test(t)) {
            newList.add(t);
        }
    }
    return newList;
}
로그인 후 복사

利用上面的函数式接口过滤字符串集合中的空字符串:

demo.filter(list, (String str) -> null != str && !str.isEmpty());
Consumer<T>
@FunctionalInterface
public interface Consumer<T> {
    /**
     * Performs this operation on the given argument.
     *
     * @param t the input argument
     */
    void accept(T t);
}
로그인 후 복사

Consumer提供了一个accept抽象函数,该函数接收参数,但不返回值,下面利用

Consumer
로그인 후 복사

遍历集合:

/**
 * 遍历集合,执行自定义行为
 *
 * @param list
 * @param consumer
 * @param 
 */
public  void filter(List list, Consumer<T> consumer) {
    for (final T t : list) {
        consumer.accept(t);
    }
}
로그인 후 복사

利用上面的函数式接口,遍历字符串集合,并打印非空字符串:

demo.filter(list, (String str) -> {
        if (StringUtils.isNotBlank(str)) {
            System.out.println(str);
        }
    });
로그인 후 복사

Function<T, R>

@FunctionalInterface
public interface Function<T, R> {
    /**
     * Applies this function to the given argument.
     *
     * @param t the function argument
     * @return the function result
     */
    R apply(T t);
}
로그인 후 복사

Funcation执行转换操作,输入是类型T的数据,返回R类型的数据,下面利用

Function
로그인 후 복사

对集合进行转换:

/**
 * 遍历集合,执行自定义转换操作
 *
 * @param list
 * @param function
 * @param 
 * @param 
 * @return
 */
public  List filter(List list, Function<T, R> function) {
    List newList = new ArrayList();
    for (final T t : list) {
        newList.add(function.apply(t));
    }
    return newList;
}
로그인 후 복사

下面利用上面的函数式接口,将一个封装字符串(整型数字的字符串表示)的接口,转换成整型集合:

demo.filter(list, (String str) -> Integer.parseInt(str));
上面这些函数式接口还提供了一些逻辑操作的默认实现,留到后面介绍java8接口的默认方法时再讲吧~

使用过程中需要注意的一些事情

类型推断

在编码过程中,有时候可能会疑惑我们的调用代码会去具体匹配哪个函数式接口,实际上编译器会根据参数、返回类型、异常类型(如果存在)等做正确的判定。

在具体调用时,在一些时候可以省略参数的类型,从而进一步简化代码:

/

/ 筛选苹果
List<Apple> filterApples = filterApplesByAppleFilter(apples,
        (Apple apple) -> Color.RED.equals(apple.getColor()) && apple.getWeight() >= 100);
// 某些情况下我们甚至可以省略参数类型,编译器会根据上下文正确判断
List<Apple> filterApples = filterApplesByAppleFilter(apples,
        apple -> Color.RED.equals(apple.getColor()) && apple.getWeight() >= 100);
로그인 후 복사

局部变量

上面所有例子我们的lambda表达式都是使用其主体参数,我们也可以在lambda中使用局部变量,如下:

int weight = 100;
List<Apple> filterApples = filterApplesByAppleFilter(apples,
        apple -> Color.RED.equals(apple.getColor()) && apple.getWeight() >= weight);
로그인 후 복사

该例子中我们在lambda中使用了局部变量weight,不过在lambda中使用局部变量必须要求该变量 显式声明为final或事实上的final ,这主要是因为局部变量存储在栈上,lambda表达式则在另一个线程中运行,当该线程视图访问该局部变量的时候,该变量存在被更改或回收的可能性,所以用final修饰之后就不会存在线程安全的问题。

四. 方法引用

采用方法引用可以更近一步的简化代码,有时候这种简化让代码看上去更加的直观,先看一个例子:

/* ... 省略apples的初始化操作 */
// 采用lambda表达式
apples.sort((Apple a, Apple b) -> Float.compare(a.getWeight(), b.getWeight()));
// 采用方法引用
apples.sort(Comparator.comparing(Apple::getWeight));
로그인 후 복사

方法引用通过

::
로그인 후 복사

将方法隶属和方法自身连接起来,主要分为三类:

静态方法

(args) -> ClassName.staticMethod(args)
로그인 후 복사


转换成

ClassName::staticMethod
로그인 후 복사


参数的实例方法

(args) -> args.instanceMethod()
로그인 후 복사


转换成

ClassName::instanceMethod  // ClassName是args的类型
로그인 후 복사


外部的实例方法

(args) -> ext.instanceMethod(args)
로그인 후 복사


转换成

ext::instanceMethod(args)
로그인 후 복사

 以上就是Java8 新特性之 Lambda 表达式 的内容,更多相关内容请关注PHP中文网(www.php.cn)!



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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

람다 표현식은 C++에서 예외를 어떻게 처리하나요? 람다 표현식은 C++에서 예외를 어떻게 처리하나요? Apr 17, 2024 pm 12:42 PM

C++에는 Lambda 표현식을 사용하여 예외를 처리하는 두 가지 방법이 있습니다. 즉, try-catch 블록을 사용하여 예외를 포착하고, catch 블록에서 예외를 처리하거나 다시 발생시킵니다. std::function 유형의 래퍼 함수를 ​​사용하면 try_emplace 메서드가 Lambda 표현식에서 예외를 포착할 수 있습니다.

C++ 람다 표현식에서 클로저의 의미는 무엇입니까? C++ 람다 표현식에서 클로저의 의미는 무엇입니까? Apr 17, 2024 pm 06:15 PM

C++에서 클로저는 외부 변수에 액세스할 수 있는 람다 식입니다. 클로저를 생성하려면 람다 표현식에서 외부 변수를 캡처하세요. 클로저는 재사용성, 정보 숨기기, 지연 평가와 같은 이점을 제공합니다. 이는 클로저가 외부 변수가 파괴되더라도 여전히 접근할 수 있는 이벤트 핸들러와 같은 실제 상황에서 유용합니다.

다중 스레드 프로그래밍에 C++ 람다 식을 사용하면 어떤 이점이 있나요? 다중 스레드 프로그래밍에 C++ 람다 식을 사용하면 어떤 이점이 있나요? Apr 17, 2024 pm 05:24 PM

C++ 다중 스레드 프로그래밍에서 람다 식의 장점에는 단순성, 유연성, 매개 변수 전달 용이성 및 병렬성이 포함됩니다. 실제 사례: 람다 식을 사용하여 다중 스레드를 만들고 다른 스레드에서 스레드 ID를 인쇄하여 이 방법의 단순성과 사용 용이성을 보여줍니다.

C++ 람다 표현식에서 클로저를 구현하는 방법은 무엇입니까? C++ 람다 표현식에서 클로저를 구현하는 방법은 무엇입니까? Jun 01, 2024 pm 05:50 PM

C++ Lambda 표현식은 함수 범위 변수를 저장하고 함수에 액세스할 수 있도록 하는 클로저를 지원합니다. 구문은 [캡처 목록](매개변수)->return-type{function-body}입니다. 캡처 목록은 캡처할 변수를 정의합니다. [=]를 사용하여 모든 지역 변수를 값으로 캡처하고, [&]를 사용하여 모든 지역 변수를 참조로 캡처하거나, [변수1, 변수2,...]를 사용하여 특정 변수를 캡처할 수 있습니다. 람다 표현식은 캡처된 변수에만 액세스할 수 있지만 원래 값을 수정할 수는 없습니다.

C++ 람다 표현식은 외부 변수를 어떻게 캡처합니까? C++ 람다 표현식은 외부 변수를 어떻게 캡처합니까? Apr 17, 2024 pm 04:39 PM

C++에서 외부 변수의 람다 식을 캡처하는 방법에는 세 가지가 있습니다. 값으로 캡처: 변수의 복사본을 만듭니다. 참조로 캡처: 변수 참조를 가져옵니다. 값 및 참조로 동시에 캡처: 값 또는 참조로 여러 변수를 캡처할 수 있습니다.

PHP 8.3 출시: 새로운 기능 한눈에 보기 PHP 8.3 출시: 새로운 기능 한눈에 보기 Nov 27, 2023 pm 12:52 PM

PHP8.3 출시: 새로운 기능 개요 기술이 계속 발전하고 변화가 필요함에 따라 프로그래밍 언어는 지속적으로 업데이트되고 개선됩니다. 웹 개발에 널리 사용되는 스크립팅 언어인 PHP는 개발자에게 더욱 강력하고 효율적인 도구를 제공하기 위해 지속적으로 개선되어 왔습니다. 최근 출시된 PHP 8.3 버전에는 오랫동안 기다려온 많은 새로운 기능과 개선 사항이 포함되어 있습니다. 이러한 새로운 기능에 대한 개요를 살펴보겠습니다. null이 아닌 속성의 초기화 이전 버전의 PHP에서는 클래스 속성에 명시적으로 값이 할당되지 않은 경우 해당 값은

C++ 함수 호출 람다 표현식: 매개변수 전달 및 반환 값에 대한 콜백 최적화 C++ 함수 호출 람다 표현식: 매개변수 전달 및 반환 값에 대한 콜백 최적화 May 03, 2024 pm 12:12 PM

C++에서는 Lambda 표현식을 함수 매개 변수로 사용하여 콜백 함수의 유연성을 얻을 수 있습니다. 구체적으로 설명하면 다음과 같습니다. 매개변수 전달: std::function을 통해 Lambda 표현식을 래핑하고 이를 함수 포인터 형식으로 함수에 전달합니다. 반환 값 처리: std::function을 사용하여 콜백 함수 포인터를 선언할 때 반환 값 유형을 지정합니다. 실제 사례: GUI 이벤트 처리에서 콜백을 최적화하고, 불필요한 객체나 함수 포인터 생성을 방지하고, 코드 단순성과 유지 관리성을 향상시킵니다.

PHP8의 새로운 기능을 배우고 최신 기술에 대한 심층적인 이해를 얻을 수 있는 가이드 PHP8의 새로운 기능을 배우고 최신 기술에 대한 심층적인 이해를 얻을 수 있는 가이드 Dec 23, 2023 pm 01:16 PM

최신 기술을 익히는 데 도움이 되는 PHP8의 새로운 기능에 대한 심층 분석입니다. 시간이 지남에 따라 PHP 프로그래밍 언어는 지속적으로 발전하고 개선되었습니다. 최근 출시된 PHP8 버전은 개발자에게 많은 흥미로운 새로운 기능과 개선 사항을 제공하여 개발 작업에 더 많은 편의성과 효율성을 제공합니다. 이 기사에서는 PHP8의 새로운 기능을 심층적으로 분석하고 이러한 최신 기술을 더 잘 익히는 데 도움이 되는 특정 코드 예제를 제공합니다. JIT 컴파일러 PHP8에는 JIT(Just-In-Time) 컴파일이 도입되었습니다.

See all articles