go - 如何避免循环依赖但保持干净的结构
问题描述
我有这个结构:
httpservice
L endpointHandler.go (it has as parameters databaseA and databaseB)
L types.gen.go (autogenerated from the api definition)
storage
L databaseA.go (each database has 'Store(Type)' and 'Get() -> Type' functions)
L databaseB.go
我的问题是我陷入循环依赖错误。endpointHandler 需要导入存储包才能访问数据库。数据库需要导入 httpservice,因为类型是在那里自动生成的(它需要类型才能存储或读取结构)。
有没有办法用接口解决这个问题?我试过了,但它并没有摆脱循环问题。我能想到的一些解决方案:
复制粘贴存储包中的类型,忽略生成的类型
移动 httpservice 包内的数据库,忘记漂亮的文件夹结构
PD:有很多关于循环依赖的问题,但我无法解决我的特定问题。抱歉,如果重复。
解决方案
如果应用程序增长 - 您可以考虑使用“端口和适配器”架构概念来反转依赖关系。
在这种情况下,您不希望从“httpservice”到低级“storage”包的依赖。(httpservice 可能充当外部接口,不应该知道存储的技术细节。事实上,存储在未来可能会有所不同)。所以你可以在“httpservice”层(包)中定义一个对该层有意义的接口(例如“mydataService interface {}”)——我称之为辅助端口。
“存储”层可以知道“httpservice”并实现一个适配器(实现定义的接口)
初始化应用程序时,请确保将正确的存储适配器注入 httpservice..
一些更大的框架也使用这种方法 - 你可能想阅读更多:https ://docs.flamingo.me/2.%20Flamingo%20Core/1.%20Flamingo%20Basics/4.%20Ports%20and%20Adapters.html
推荐阅读
- compiler-construction - 边缘分割 SSA 的使用
- java - 从 int 中获取值,然后保存在数组中并计算模数
- android - Object 类方法上的空指针异常
- windows - 将文件从远程 Windows 机器复制到没有 Cygwin 的 Linux 机器
- c++ - Boost::Process 管道链
- javascript - 在 c3.js 图表中加载动态 JSON 数据,标签未填充
- java - 带有通配符的 Java 导入不起作用,而没有通配符的导入起作用
- python - Tensorflow 在类方法调用上设置图/会话上下文
- ios - Swift-获取具有不同时区的当前日期以在时间之间进行比较
- php - 在视图页面PHP中显示数组数组