ass*_*ias 152 java lambda serialization java-8
我怎样才能优雅地序列化lambda?
例如,下面的代码抛出一个NotSerializableException.如何在不创建SerializableRunnable"虚拟"界面的情况下修复它?
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();
}
}
Run Code Online (Sandbox Code Playgroud)
ass*_*ias 250
Java 8引入了通过添加多个边界将对象强制转换为类型的交集的可能性.在序列化的情况下,因此可以写:
Runnable r = (Runnable & Serializable)() -> System.out.println("Serializable!");
Run Code Online (Sandbox Code Playgroud)
lambda自动变为可序列化.
Vic*_*ero 23
相同的结构可用于方法参考.例如这段代码:
import java.io.Serializable;
public class Test {
static Object bar(String s) {
return "make serializable";
}
void m () {
SAM s1 = (SAM & Serializable) Test::bar;
SAM s2 = (SAM & Serializable) t -> "make serializable";
}
interface SAM {
Object action(String s);
}
}
Run Code Online (Sandbox Code Playgroud)
定义lambda表达式和具有可序列化目标类型的方法引用.
小智 17
非常丑陋的演员.我更喜欢为我正在使用的功能接口定义Serializable扩展
例如:
interface SerializableFunction<T,R> extends Function<T,R>, Serializable {}
interface SerializableConsumer<T> extends Consumer<T>, Serializable {}
Run Code Online (Sandbox Code Playgroud)
那么接受lambda的方法可以这样定义:
private void someFunction(SerializableFunction<String, Object> function) {
...
}
Run Code Online (Sandbox Code Playgroud)
并调用函数,您可以传递您的lambda没有任何丑陋的演员:
someFunction(arg -> doXYZ(arg));
Run Code Online (Sandbox Code Playgroud)