Ich habe eine Protobuf-Nachricht, die an mehrere Clients gesendet werden muss. Die Nachricht enthält für jeden Mandanten die gleichen Daten, mit Ausnahme eines Feldes (Sequenznummer), das für jeden Mandanten unterschiedlich ist. Jetzt kann ich die Felder im generierten Java-Nachrichtenobjekt ändern und die Nachricht für jeden Client separat serialisieren. Aber gibt es eine Möglichkeit, alles außer einem Feld zu serialisieren und dieses Feld dann einfach für jeden Client zu serialisieren (z. B. die entsprechenden Bytes in der serialisierten Nachricht auszutauschen oder so)?
BEARBEITEN: Ich habe die mergeFrom-Methode zum Zusammenführen zweier Nachrichten gesehen, aber soweit ich weiß, analysiert sie zuerst die Nachricht, tauscht dann die Daten aus, und dann können Sie sie erneut serialisieren, es handelt sich also überhaupt nicht um eine Leistungsoptimierung (?).
Zunächst möchte ich ziemlich sicher sein, dass es tatsächlich um die Leistung geht. Wenn die Protokollpuffernachrichten nicht groß sind (ich würde dies nicht einmal in Betracht ziehen, wenn sie nicht mehrere Kilobyte groß wären), würde ich davon ausgehen, dass dies praktisch keine Auswirkungen auf die Leistung hat, und Sie sollten nicht einmal versuchen, sie zu optimieren
Das ist nicht schwierig, vorausgesetzt, Sie haben es für einen Engpass gehalten. Verketten Sie das Zusammenführungsformular des serialisierten Prototypkonstruktors, also ist dies vermutlich
myMessage.toBuilder().clearSpecialField().build().writeTo(outputStream); MyMessage.newBuilder().setSpecialField(...).build().writeTo(outputStream);
(Wenn Sie special_field
作为必填字段(违反最佳实践),那么您可能需要改用 buildPartial
haben.)
Dann lesen Sie es als Rohbotschaft
MyMessage.parseFrom(inputStream);
Das obige ist der detaillierte Inhalt vonTeilweise Serialisierung gemeinsamer Felder in Java durch Protobuf. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!