Heim > Java > Teilweise Serialisierung gemeinsamer Felder in Java durch Protobuf

Teilweise Serialisierung gemeinsamer Felder in Java durch Protobuf

WBOY
Freigeben: 2024-02-12 15:45:06
nach vorne
1264 Leute haben es durchsucht

Frageninhalt

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 (?).

Workaround

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);
Nach dem Login kopieren

(Wenn Sie special_field 作为必填字段(违反最佳实践),那么您可能需要改用 buildPartial haben.)

Dann lesen Sie es als Rohbotschaft

MyMessage.parseFrom(inputStream);
Nach dem Login kopieren

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!

Quelle:stackoverflow.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage