Maison > Java > Sérialisation partielle Protobuf des champs communs en Java

Sérialisation partielle Protobuf des champs communs en Java

WBOY
Libérer: 2024-02-12 15:45:06
avant
1258 Les gens l'ont consulté

Contenu de la question

J'ai un message protobuf qui doit être envoyé à plusieurs clients. Le message contient les mêmes données pour chaque client, à l'exception d'un champ (numéro de séquence) différent pour chaque client. Je peux désormais modifier les champs de l'objet de message Java généré et sérialiser le message séparément pour chaque client. Mais existe-t-il un moyen de tout sérialiser sauf un champ, puis de simplement sérialiser ce champ pour chaque client (par exemple, échanger les octets correspondants dans le message sérialisé ou quelque chose du genre) ?

EDIT : j'ai vu la méthode mergeFrom pour fusionner deux messages, mais d'après ce que j'ai compris, elle analyse d'abord le message, puis échange les données, puis vous pouvez les sérialiser à nouveau, ce n'est donc pas du tout une optimisation des performances (?).

Solution de contournement

Tout d'abord, je veux être sûr que cela est réellement lié aux performances. Si les messages du tampon de protocole ne sont pas volumineux (je n'envisagerais même pas cela s'ils ne faisaient pas plusieurs kilo-octets), alors je m'attendrais à ce que cela n'ait pratiquement aucun impact sur les performances, et vous ne devriez même pas essayer de l'optimiser

.

Ce n'est pas difficile en supposant que vous l'ayez considéré comme un goulot d'étranglement. Concaténez le formulaire de fusion du constructeur de prototype sérialisé, donc probablement c'est

myMessage.toBuilder().clearSpecialField().build().writeTo(outputStream);
MyMessage.newBuilder().setSpecialField(...).build().writeTo(outputStream);
Copier après la connexion

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

Ensuite, vous le lisez comme un message brut

MyMessage.parseFrom(inputStream);
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:stackoverflow.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal