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