Próbuję serializować strukturę z protobuf. po wiele godzin próbuje dowiedzieć się, co robię źle postanowiłem przetestować przykład Google i nie pracował jak dobrzebłąd z serializacją z protobuf
Mam następujący protokół z google (https://developers.google.com/protocol-buffers/docs/javatutorial):
package tutorial;
option java_package = "com.example.tutorial";
option java_outer_classname = "AddressBookProtos";
message Person {
required string name = 1;
required int32 id = 2;
optional string email = 3;
repeated PhoneNumber phone = 4;
enum PhoneType {
MOBILE = 0;
HOME = 1;
WORK = 2;
}
message PhoneNumber {
required string number = 1;
optional PhoneType type = 2 [default = HOME];
}
}
message AddressBook {
repeated Person person = 1;
}
i staram się szeregować je:
Person john = Person.newBuilder()
.setId(1234)
.setName("John Doe")
.setEmail("[email protected]")
.addPhone(
Person.PhoneNumber.newBuilder()
.setNumber("555-4321")
.setType(Person.PhoneType.HOME))
.build();
byte [] w odcinkach = john.toByteArray();
i otrzymuję "java.lang.UnsupportedOperationException: ma to być nadpisane przez podklasy."
Dzięki;
Czy możesz opublikować kompletny stacktrace? – rongenre
Czy użyłeś wersji 'protoc', która pasowała do używanej biblioteki? –
Używałem różnych wersji protobuf ... Wielkie dzięki, Marc! – Fynn