Java 프로그래밍에서는 람다 식을 직렬화해야 하는 시나리오를 흔히 접하게 됩니다. 그러나 람다를 직접 직렬화하려고 시도하면 NotSerializedException이 발생하는 경우가 많습니다.
다음 예를 고려하세요.
public static void main(String[] args) throws Exception { File file = Files.createTempFile("lambda", "ser").toFile(); try (ObjectOutput oo = new ObjectOutputStream(new FileOutputStream(file))) { Runnable r = () -> System.out.println("Can I be serialized?"); oo.writeObject(r); } try (ObjectInput oi = new ObjectInputStream(new FileInputStream(file))) { Runnable r = (Runnable) oi.readObject(); r.run(); } }
이 경우 람다를 직렬화하면 NotSerializedException이 발생합니다.
이 문제를 극복하기 위해 Java 8은 개체를 유형의 교차점으로 캐스팅하는 영리한 솔루션을 도입합니다. 람다 유형에 여러 범위를 추가하면 람다 유형을 우아하게 직렬화할 수 있습니다.
Runnable r = (Runnable & Serializable)() -> System.out.println("Serializable!");
이 기술을 사용하면 람다가 직렬화 가능 인터페이스를 자동으로 상속하여 "더미" 없이도 직렬화할 수 있습니다. SerializedRunnable 인터페이스.
위 내용은 더미 인터페이스를 생성하지 않고 Java에서 람다 표현식을 직렬화하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!