Maison >développement back-end >Golang >Go bonnes pratiques en matière d'injection de dépendances linguistiques

Go bonnes pratiques en matière d'injection de dépendances linguistiques

WBOY
WBOYoriginal
2024-04-07 15:42:021223parcourir

Les meilleures pratiques pour implémenter l'injection de dépendances dans Go incluent : Couplage lâche : couplez de manière lâche des objets avec leurs dépendances pour améliorer la testabilité et la maintenabilité. Testabilité : améliorez la crédibilité des tests en vous moquant des dépendances pour les tests unitaires. Évolutivité : améliorez l'évolutivité de votre code en modifiant ou en ajoutant facilement des dépendances. Implémentez DI à l'aide de bibliothèques tierces comme wire, définissez des interfaces et créez des dépendances à l'aide de wire.NewSet.

Go bonnes pratiques en matière dinjection de dépendances linguistiques

Meilleures pratiques d'injection de dépendances dans le langage Go

L'injection de dépendances (DI) est un modèle de conception logicielle qui permet d'injecter des dépendances dans des objets au moment de l'exécution. Dans le langage Go, DI contribue à améliorer la testabilité, l'évolutivité et la maintenabilité du code.

Avantages de DI

  • Couplage lâche : Avec DI, un objet est faiblement couplé à ses dépendances, ce qui rend les tests et la refactorisation plus pratiques.
  • Testabilité : DI permet des tests unitaires d'objets en utilisant des dépendances fictives, augmentant ainsi la crédibilité des tests.
  • Évolutivité :  DI facilite la modification des dépendances ou l'ajout de nouvelles, augmentant ainsi l'évolutivité de votre code.

Implémentation de DI dans le langage Go

Le langage Go a une prise en charge intégrée très limitée pour DI. Par conséquent, il est souvent nécessaire d’utiliser une bibliothèque tierce pour implémenter DI. Une bibliothèque populaire est [wire](https://github.com/google/wire).

Pour utiliser wire, vous devez d'abord définir une interface qui contient toutes les dépendances :

type MyServiceDeps struct {
    Repository Repository
    Logger     Logger
}

Ensuite, vous pouvez utiliser la fonction wire.NewSet pour créer la structure requise : wire.NewSet 函数创建所需的结构:

func NewMyService(deps MyServiceDeps) MyService {
    return MyService{
        repository: deps.Repository,
        logger:     deps.Logger,
    }
}

最后,使用 InitInjector 函数生成依赖项注入器:

func main() {
    wire.Build(
        NewMyService,
        NewRepository,
        NewLogger,
    )
}

实战案例

考虑一个シンプルな Web 应用程序,它需要与数据库和 HTTP 服务器交互。我们可以使用 DI 来创建松散耦合的服务,这些服务可以独立于特定依赖项进行测试:

// 定义依赖项接口
type UserRepo interface {
    GetUser(id int) (*User, error)
}

type HTTPServer interface {
    Start() error
}

// 定义服务结构
type UserService struct {
    repo UserRepo
}

// 实现用户服务方法
func (s *UserService) GetUser(id int) (*User, error) {
    return s.repo.GetUser(id)
}

// 定义 DI 函数
func NewUserService(r UserRepo) *UserService {
    return &UserService{
        repo: r,
    }
}

// 初始化 DI 注入器,并启动 HTTP 服务器
func main() {
    injector, err := wire.Build(
        NewUserService,
        NewUserRepository,
        NewHTTPServer,
    )
    if err != nil {
        panic(err)
    }

    server := injector.Get(NewHTTPServer)
    server.Start()
}

在这个示例中,DI 使我们能够在不修改 UserServicerrreee

Enfin, utilisez La fonction InitInjector génère un injecteur de dépendances : 🎜rrreee🎜🎜Cas pratique🎜🎜🎜Considérons une シンプルなApplication Web qui doit interagir avec une base de données et un serveur HTTP. Nous pouvons utiliser DI pour créer des services faiblement couplés qui peuvent être testés indépendamment de dépendances spécifiques : 🎜rrreee🎜 Dans cet exemple, DI nous permet d'apporter des modifications sans modifier la base de données de code UserService ou l'implémentation du serveur HTTP. 🎜

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:
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