在 go 中,依赖注入 (di) 模式通过函数参数传递实现,类型包括值传递和指针传递。在 di 模式中,依赖项通常以指针传递,以提高解耦性、减少锁争用和支持可测试性。通过使用指针,函数与具体实现解耦,因为它只依赖于接口类型。指针传递还可以减少传递大对象的开销,从而减少锁争用。此外,di 模式可以轻松地为使用 di 模式的函数编写单元测试,因为可以轻松地模拟依赖项。
Go 语言中的函数参数传递依赖注入模式
简介
依赖注入 (DI) 是一种设计模式,允许对象以解耦的方式获取其依赖项。在 Go 中,DI 通常通过函数参数传递来实现。
参数传递的类型
Go 中函数参数传递有两种类型:
- 值传递:参数变量是原始值的副本,对参数变量的任何更改都不会影响原始值。
- 指针传递:参数变量是一个指向原始值的指针,对参数变量的更改也会影响原始值。
DI 模式中的参数传递
在 DI 模式中,依赖项通常以指针传递。这样做的好处如下:
- 提高解耦性:通过使用指针,函数与具体实现解耦,因为它只依赖于接口类型。
- 减少锁争用:传递指针可以减少传递大对象的开销,从而减少锁争用。
- 支持可测试性:更容易为使用 DI 模式的函数编写单元测试,因为可以轻松地模拟依赖项。
实战案例
考虑一个 UserService,它需要访问 User Repository:
type UserService struct { userRepository UserRepository } func (s *UserService) CreateUser(user *User) error { return s.userRepository.Create(user) }