许多 Go 开发者都会遇到神秘的错误消息:“imports runtime/internal/atomic: use of inside package不允许。”本文深入探讨了此限制背后的基本原理,并探讨了在 Go 中处理内部包的替代方法。
Go 遵循明确定义的包边界的原则。然而,项目规模不可避免地会扩大,从而导致将代码组织到多个包中同时保留模块间依赖关系的挑战。传统上,将库拆分为内部包使它们可以在项目内访问,但对外部使用者隐藏。
在 Go 1.4 中,一项旨在通过以下方式解决此问题的提案:引入可见性限制。外部代码将无法访问路径中包含“内部”元素的包。该规则旨在维护封装并防止内部 API 的意外暴露。
尽管提出了规则,但仍然禁止从项目树外部导入内部包。 Go 的打包设计优先考虑简单性和可维护性,通过当前包系统的管道实现内部可见性并非易事。
虽然不鼓励直接导入内部包,但有是实现类似功能的替代方法:
Go 语言不支持导入内部包,通常应该避免。推荐的方法优先考虑封装,同时保持 Go 包系统的完整性。
以上是为什么我无法导入 Go 的内部包,有哪些替代方法?的详细内容。更多信息请关注PHP中文网其他相关文章!