2

我正在使用 protostuff 将我自己的类的对象转换为 JSON,反之亦然。有 java 8 和 lambdas。转换为 JSON 文件,如:

LinkedBuffer buffer = LinkedBuffer.allocate(2048);
Schema schema = RuntimeSchema.getSchema(obj.getClass());
boolean numeric = false;
byte[] json = JsonIOUtil.toByteArray(obj, schema, numeric, buffer);
Files.write(file, json);

从 JSON 转换为 obj:

Schema<MyClass> schema = RuntimeSchema.getSchema(MyClass.class);
Path path = Paths.get("path");
byte[] as = Files.readAllBytes(path);
MyClass mc = schema.newMessage();
JsonIOUtil.mergeFrom(as, mc, schema, false);

当我尝试将 JSON 转换为 obj 时出现异常:

线程“主”java.lang.RuntimeException 中的异常:java.lang.ClassNotFoundException:com.test.Blabla$$Lambda$4/1699679644

我认为 lambda 是一个问题。我可以用它转换课程吗?

对象有一个字段:

private final Function<,> name;
4

1 回答 1

4

您的 lambda 是运行时表达式,无法序列化。它实际上是一个方法指针,在您运行的序列化代码中有效。接收代码(反序列化)如何处理这样的方法指针,指向发送代码中的方法?

如果您的发送代码与接收代码相同,并且 lambda 表达式的可能值是一组明确定义的不同方法,您应该考虑实现枚举并仅序列化枚举值:

public enum Lambdas
{
    FIRST( s -> new String()),
    SECOND( s -> s + " ");

    private Function<String, String> myLambda;

    private Lambdas( Function<String, String> aLambda )
    {
        myLambda = aLambda;
    }

    public Function<String, String> getLambda()
    {
        return myLambda;
    }
}

如果您的 Person 现在有成员

private Lambdas myLambda;

(这是可序列化的)您的接收代码可以像这样使用它:

String result = myLambda.getLambda().apply();
于 2016-05-16T11:10:50.887 回答