Използвам Kryonet за TCP изпращане на обекти, особено един, наречен TransferMessage:
public static class TransferMessage{String text; String username; Color color = Color.black;}
Сега знам, че трябва да извикам kryo.register(TransferMessage.class)
, но когато се опитам да се свържа със сървъра с всички регистрирани класове, получавам грешка:
Exception in thread "Server" com.esotericsoftware.kryo.KryoException: java.lang.IllegalArgumentException: Class is not registered: java.awt.Color
Note: To register this class use: kryo.register(java.awt.Color.class);
Serialization trace:
color (com.andrewlalisofficial.MessageTypes$TransferMessage)
at com.esotericsoftware.kryo.serializers.FieldSerializer$ObjectField.write(FieldSerializer.java:585)
at com.esotericsoftware.kryo.serializers.FieldSerializer.write(FieldSerializer.java:213)
at com.esotericsoftware.kryo.Kryo.writeClassAndObject(Kryo.java:571)
at com.esotericsoftware.kryonet.KryoSerialization.write(KryoSerialization.java:50)
at com.esotericsoftware.kryonet.TcpConnection.send(TcpConnection.java:192)
at com.esotericsoftware.kryonet.Connection.sendTCP(Connection.java:59)
at com.esotericsoftware.kryonet.Server.sendToAllTCP(Server.java:435)
at com.andrewlalisofficial.ChatServer.sendMessage(ChatServer.java:204)
at com.andrewlalisofficial.ChatServer.checkCommand(ChatServer.java:124)
at com.andrewlalisofficial.ChatServer$1.received(ChatServer.java:72)
at com.esotericsoftware.kryonet.Server$1.received(Server.java:61)
at com.esotericsoftware.kryonet.Connection.notifyReceived(Connection.java:246)
at com.esotericsoftware.kryonet.Server.update(Server.java:208)
at com.esotericsoftware.kryonet.Server.run(Server.java:356)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.lang.IllegalArgumentException: Class is not registered: java.awt.Color
Не разбирам, защото въпреки че регистрираният ми клас използва класа Color, никога преди не ми се е налагало да регистрирам String
обекти, така че не виждам каква е разликата тук и как да поправя тази грешка? Благодаря ви предварително за помощта.
РЕДАКТИРАНЕ:
Ето минимален възпроизводим код, показващ грешка при сериализиране на Color
:
// this works actually fine
public static void main(String[] args) {
Kryo kryo = new Kryo();
kryo.register(Color.class, new JavaSerializer());
Color color = new Color(15006);
Output output = new Output(new byte[1024]);
kryo.writeObject(output, color);
Input input = new Input(output.getBuffer());
Color color2 = kryo.readObject(input, Color.class);
if (!color.equals(color2)) throw new AssertionError();
}
KryoRegistrator
и бих използвал един за инициализиране на единKryo
екземпляр от всяка страна на TCP връзката. Това би гарантирало, че двете страни са регистрирали едни и същи класове с едни и същи сериализатори - person Dici   schedule 01.10.2015JavaSerializer
, когато е направено правилно. Не знам какъв точно ти е проблемът. Погледнах кода наColor
и изглежда, че много данни ще бъдат сериализирани, докато могат просто да бъдат реконструирани след десериализация. Мисля, че можете спокойно да се придържате към персонализирания сериализатор, той е малко по-ефективен, освен ако реконструирането на частните атрибути, които не сериализираме, е по-скъпо от цената на мрежата за тяхното сериализиране - person Dici   schedule 01.10.2015