首頁 >後端開發 >Golang >為什麼我無法匯入 Go 的內部包,有哪些替代方法?

為什麼我無法匯入 Go 的內部包,有哪些替代方法?

Barbara Streisand
Barbara Streisand原創
2024-11-25 11:49:18955瀏覽

Why Can't I Import Go's Internal Packages, and What Are the Alternatives?

在Go 中匯入內部套件:受限可見性之旅

許多Go 開發者都會遇到神秘的錯誤訊息:「imports runtime/internal/atomic : use of inside package不允許。

內部可見性的張力

Go 遵循明確定義的包邊界的原則。然而,專案規模不可避免地會擴大,從而導致將程式碼組織到多個套件中同時保留模組間依賴關係的挑戰。傳統上,將庫拆分為內部包使它們可以在項目內訪問,但對外部用戶隱藏。

Go 1.4 的建議解決方案

在 Go 1.4 中,一項旨在透過以下方式解決此問題的提案:引入可見性限制。外部程式碼將無法存取路徑中包含「內部」元素的套件。該規則旨在維護封裝並防止內部 API 的意外暴露。

現實

儘管提出了規則,但仍禁止從專案樹外部匯入內部套件。 Go 的打包設計優先考慮簡單性和可維護性,透過目前套件系統的管道實現內部可見性並非易事。

替代方法

雖然不鼓勵直接導入內部包,但有是實現類似功能的替代方法:

  • 匿名導入:匯入具有匿名名稱的套件,以避免與公用套件發生衝突。例如,_“runtime/internal/atomic”有效地導入包而不暴露其符號。
  • 供應商目錄:使用供應商目錄來管理第三方包並控制可見性。這可以透過從供應商目錄中的“內部”子目錄匯入套件來實現。
  • 單獨的儲存庫:對於較大的項目,請考慮將內部套件拆分到單獨的儲存庫中。這確保了封裝並防止外部存取。

結論

Go 語言不支援導入內部包,通常應該避免。建議的方法優先考慮封裝,同時保持 Go 套件系統的完整性。

以上是為什麼我無法匯入 Go 的內部包,有哪些替代方法?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn