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

Sérialisation partielle Protobuf des champs communs en Java

WBOY
WBOYavant
2024-02-12 15:45:061246parcourir

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);

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

Ensuite, vous le lisez comme un message brut

MyMessage.parseFrom(inputStream);

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer