我正在使用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;

最佳答案

您的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;
    }
}


如果您的人员现在有成员

private Lambdas myLambda;


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

String result = myLambda.getLambda().apply();

10-07 15:56
查看更多