Maison >développement back-end >Golang >Comment « mustEmbedUnimplemented » de gRPC améliore-t-il la compatibilité ascendante du serveur ?
Compatibilité ascendante dans gRPC avec mustEmbedUnimplemented*
La bibliothèque gRPC-go a introduit la méthode mustEmbedUnimplemented*** pour améliorer la compatibilité ascendante dans le serveur implémentations.
Dans le passé, les serveurs gRPC échouaient à la compilation si les méthodes requises n'étaient pas mis en œuvre. Pour atténuer ce problème, les développeurs ont dû implémenter manuellement des méthodes non implémentées, même si elles n'étaient pas destinées à être utilisées.
mustEmbedUnimplemented* résout ce problème en désactivant la compatibilité ascendante. Cela signifie que :
Par exemple, si vous avez un Interface GreetService :
type GreetService interface { Greet(ctx context.Context, req *pb.GreetRequest, opts ...gax.CallOption) (*pb.GreetResponse, error) }
Vous l'implémentiez auparavant comme :
type server struct {...} func (s *server) Greet(ctx context.Context, req *pb.GreetRequest, opts ...gax.CallOption) (*pb.GreetResponse, error) {...} func (s *server) MustEmbeddUnimplementedGreetServiceServer() {...}
Maintenant, avec mustEmbedUnimplemented***, vous pouvez désactiver la compatibilité ascendante en intégrant des interfaces Unsafe*** à la place :
type server struct { grpc.UnsafeGreetServiceServer ... }
Ce changement offre une plus grande flexibilité et évite le code inutile dans les implémentations de votre serveur.
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!