Giter VIP home page Giter VIP logo

Comments (4)

theigl avatar theigl commented on July 19, 2024

Hi @szhsjsu.

Do you need to write a custom serializer? Can't you simply use references?

from kryo.

szhsjsu avatar szhsjsu commented on July 19, 2024

Hi,

Thanks so much for the quick reply! Yeah, I think I need some serializers cause I have nodel/link/tree/graph classes that are referenced each other. I just created a new node serializer and it worked well.

Below is the code,

public class NodeSerializer extends Serializer<Node> {

@Override
public void write(Kryo kryo, Output output, Node node) {
    output.writeInt(node.id);
    kryo.writeClassAndObject(output, node.entryNode);
    kryo.writeClassAndObject(output, node.escapeNode);
    kryo.writeClassAndObject(output, node.skipNode);
    kryo.writeClassAndObject(output, node.charTrigger);
    kryo.writeClassAndObject(output, node.referenceTrigger);
    output.writeBoolean(node.isEnd);
}

@Override
public Node read(Kryo kryo, Input input, Class<? extends Node> type) {
    int id = input.readInt();
    Node node = new Node(id);
    node.entryNode = (Node) kryo.readClassAndObject(input);
    node.escapeNode = (Node) kryo.readClassAndObject(input);
    node.skipNode = (Node) kryo.readClassAndObject(input);
    node.charTrigger = (HashMap<Character, List<Node>>) kryo.readClassAndObject(input);
    node.referenceTrigger = (HashMap<Integer, List<Node>>) kryo.readClassAndObject(input);
    node.isEnd = input.readBoolean();
    return node;
} 

But I am not sure if this is a good solution for my problem? #

Hi @szhsjsu.

Do you need to write a custom serializer? Can't you simply use references?

from kryo.

theigl avatar theigl commented on July 19, 2024

Normally, if you have data structures with reference cycles, I would recommend using Kryo.setReferences(true).

from kryo.

szhsjsu avatar szhsjsu commented on July 19, 2024

Normally, if you have data structures with reference cycles, I would recommend using Kryo.setReferences(true).

I'll try. Thanks again~

from kryo.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.