Desidero utilizzare Apache Avro per serializzare i miei dati, il mio client è scritto in C++ e il mio server è scritto in Java.Come utilizzare apache avro GenericRecord per dati dinamici?
Il mio codice Java server è simile al seguente:
Schema scm = new Schema.Parser().parse("....shcema String....."); ByteArrayInputStream inputStream = new ByteArrayInputStream(record.array()); Decoder coder = new DecoderFactory().directBinaryDecoder(inputStream, null); GenericDatumReader<GenericRecord> reDatumReader = new GenericDatumReader<GenericRecord>(scm); try { GenericRecord result = (GenericRecord)reDatumReader.read(null, coder); //here! the result "name", "num_groups" is empty! System.out.println(result.get("name")+" "+result.get("num_groups")); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }
E il mio codice cliente:
std::string schemaDescript ="....shcema String....."; std::stringstream rsStream(schemaDescript); avro::ValidSchema rSchema; avro::compileJsonSchema(rsStream, rSchema); avro::EncoderPtr encoder = avro::binaryEncoder(); std::auto_ptr<avro::OutputStream> oStream = avro::memoryOutputStream(); encoder->init(*oStream); avro::GenericDatum rData(rSchema); avro::GenericRecord sReord = rData.value<avro::GenericRecord>(); sReord.setFieldAt(0, avro::GenericDatum("i am nice")); sReord.setFieldAt(1, avro::GenericDatum(1)); sReord.setFieldAt(2, avro::GenericDatum(12)); sReord.setFieldAt(3, avro::GenericDatum(13)); avro::GenericWriter gwriter(rSchema, encoder); gwriter.write(rData); oStream->flush(); std::auto_ptr<avro::InputStream> inSt = avro::memoryInputStream(*oStream); avro::StreamReader instReader(*inSt); size_t outputLen = oStream->byteCount(); uint8_t* theByteData = new uint8_t[outputLen]; instReader.hasMore(); instReader.readBytes(theByteData, outputLen);
mando il theByteData
al server, il codice funziona (nessuna eccezione), ma il risultato è vuoto, qualcuno può dirmi cosa c'è che non va?
E perché in Java si ottiene valore con chiave: result.get("name")
; ma in C++ otteniamo valore con indice: record.fieldAt(0).value<string>()
. Se non riesco a ottenere il valore con la chiave stringa, come abbinare l'indice alla chiave stringa?
Grazie alla dominikh, a cura mia domanda. – user1833610
3 anni dopo, qualche notizia? –