欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go模塊布局管理文檔翻譯理解

 更新時間:2023年12月14日 09:48:00   作者:cainmusic  
這篇文章主要為大家介紹了Go模塊布局管理文檔翻譯理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

Organizing a Go module

原文:https://go.dev/doc/modules/layout

新的Go開發(fā)者經(jīng)常會提出一個問題:如何組織一個Go項目?這個問題主要指文件和文件夾布局方面。

本文的目標(biāo)是提供一些有助于回答這個問題的準(zhǔn)則。為了充分利用本文,請確保你熟悉Go模塊的基本概念,你可以閱讀下面兩個文檔:

Go項目可以包括包、命令行程序或者是這兩者的組合,本文按項目類型來組織。

Basic package

一個基本的Go包可以把所有代碼放在項目的根目錄中。該項目由單個包,即單個模塊組成。

對于最簡單的包,只需要一個Go文件(不包含test文件),項目結(jié)構(gòu)是:

project-root-directory/
  go.mod
  modname.go
  modname_test.go

包名與模塊名的最后一個路徑組件匹配,modname中的包聲明代碼如下:
(譯者注:實際上不同名也可以,但易用性很差,不建議這樣做,或者至少要在文檔中明確說明)

package modname
// ... package code here

如果這個目錄上傳到GitHub存儲庫github.com/someuser/modname,那么go.mod文件中的模塊行應(yīng)表述如下:

module github.com/someuser/modname

用戶若需要依賴這個包,可以按如下方法導(dǎo)入:

import "github.com/someuser/modname"

一個Go包可以被分隔為多個文件,所有文件處于同一目錄中,如:

project-root-directory/
  go.mod
  modname.go
  modname_test.go
  auth.go
  auth_test.go
  hash.go
  hash_test.go

目錄中的所有文件都需要聲明包名modname。

Basic command

基本的可執(zhí)行程序(或命令行工具)是根據(jù)其復(fù)雜程度和代碼量大小來構(gòu)建的。

最簡單的程序由一個定義了main函數(shù)的Go文件組成。

更大的程序可以將代碼分隔到多個文件中,并且所有文件都聲明包名main,如:

project-root-directory/
  go.mod
  auth.go
  auth_test.go
  client.go
  main.go

這里的main.go文件包含main函數(shù),但這只是一種慣例。“主”文件也可以被叫做modname.go(以匹配包名)或其他任何名字。

如果這個目錄上傳到GitHub存儲庫github.com/someuser/modname,那么go.mod文件中的模塊行影表述如下:

module github.com/someuser/modname

用戶若需要使用這個程序,可以按如下方法安裝:

$ go install github.com/someuser/modname@latest

Package or command with supporting packages

更大的包或命令行工具(command)受益于將一部分功能分隔到支援包中。
(譯者注:這段翻譯可讀性有點差,我個人覺得主要是原文表意就不太明確,主要想表達的應(yīng)該是更大的包或command基于可讀性和功能隔離等需求,應(yīng)該將部分功能分隔到supporting packages中)

起初,我們建議將這些包放入internal目錄中,這樣可以防止外部依賴或避免不需要的代碼暴露。由于外部程序不能導(dǎo)入我們internal目錄中的代碼,我們可以任意重構(gòu)或者改變代碼,而不會影響外部用戶。

這樣的包的項目結(jié)構(gòu)如下:

project-root-directory/
  internal/
    auth/
      auth.go
      auth_test.go
    hash/
      hash.go
      hash_test.go
  go.mod
  modname.go
  modname_test.go

modname.go文件聲明包名modname,auth.go文件聲明包名auth,依此類推。

modname.go可以按如下方法導(dǎo)入auth包:

import "github.com/someuser/modname/internal/auth"

使用internal目錄保存支援包的命令行工具的布局類似,區(qū)別僅為,根目錄中的文件(都)應(yīng)該聲明包名main。

Multiple packages

一個模塊可以由多個可導(dǎo)入的包組成,每個包都有自己的目錄,并可以分層構(gòu)建,如下:

project-root-directory/
  go.mod
  modname.go
  modname_test.go
  auth/
    auth.go
    auth_test.go
    token/
      token.go
      token_test.go
  hash/
    hash.go
  internal/
    trace/
      trace.go

提醒一下,我們假設(shè)go.mod中的模塊行如下:

import "github.com/someuser/modname"

子包可以被其他用戶用如下方法導(dǎo)入:

import "github.com/someuser/modname/auth"
import "github.com/someuser/modname/auth/token"
import "github.com/someuser/modname/hash"

而放在internal/trace目錄中的trace包則不能被外部模塊導(dǎo)入。

建議盡可能的將包保存在internal目錄下。
(譯者注:這個說法原文并沒有給出明確的解釋,理由和是否遵循這一建議大家可以各自發(fā)揮)

Multiple commands

一個項目中的多個可執(zhí)行程序通常有不同的目錄,如下:

project-root-directory/
  go.mod
  internal/
    ... shared internal packages
  prog1/
    main.go
  prog2/
    main.go

在各自的目錄中,程序的Go文件聲明包名main。頂級的internal目錄可以存放多個程序共用的包。

用戶可以按如下方法安裝這些程序:

$ go install github.com/someuser/modname/prog1@latest
$ go install github.com/someuser/modname/prog2@latest

一個常見的約定是將同一個倉庫的命令行程序都放入cmd目錄。

在一個只由命令行程序構(gòu)成的項目中,這不是嚴(yán)格必須的。

但在由可導(dǎo)出包和命令行程序構(gòu)成的混合倉庫中,這種用法是非常有效的,接下來便會討論。

Packages and commands in the same repository

有時候一個倉庫既提供可導(dǎo)出包,也提供具有相關(guān)功能的可安裝命令行程序。如下:

project-root-directory/
  go.mod
  modname.go
  modname_test.go
  auth/
    auth.go
    auth_test.go
  internal/
    ... internal packages
  cmd/
    prog1/
      main.go
    prog2/
      main.go

假設(shè)這個模塊被命名為github.com/someuser/modname。

用戶可以按照下面的方法導(dǎo)入模塊,或者安裝命令:

Go文件中:

import "github.com/someuser/modname"
import "github.com/someuser/modname/auth"

命令行中:

$ go install github.com/someuser/modname/cmd/prog1@latest
$ go install github.com/someuser/modname/cmd/prog2@latest

Server project

Go是實現(xiàn)服務(wù)器的常用語言。

考慮到服務(wù)器的種類繁多,比如協(xié)議(REST、gRPC等)、部署、前端、容器化、腳本等等,這類項目的目錄結(jié)構(gòu)存在很大差異。

我們重點介紹其中Go語言編寫的項目部分。

由于服務(wù)器通常是一個(或多個)自包含的二進制文件,因此服務(wù)器程序通常不需要對外導(dǎo)出包,所以建議將提供服務(wù)器邏輯的Go模塊放入internal目錄。

另外,由于程序可以包含其他非Go文件,所以將所有Go命令行程序放在cmd目錄下是個好主意。

如下:

project-root-directory/
  go.mod
  internal/
    auth/
      ...
    metrics/
      ...
    model/
      ...
  cmd/
    api-server/
      main.go
    metrics-analyzer/
      main.go
    ...
  ... the project's other directories with non-Go code

考慮到服務(wù)器倉庫可能產(chǎn)生一些對外部程序也十分有用的包,最好的方法是將這些包剝離出來形成單獨的模塊。
(譯者注:這里并沒有詳細說明建議剝離出的包是當(dāng)前項目導(dǎo)出包還是拆分成單獨的項目,大家各自發(fā)揮)

譯者結(jié)語

前面的內(nèi)容基本就是原文的翻譯了。

簡單總結(jié)如下:

Go的包隔離層級為:目錄。同一個目錄下的Go文件都聲明為同一個包。

Go語言的包管理遵循下面的幾條原則:

  • 簡便。最簡便的包和程序不需要復(fù)雜的布局。
  • 私用。盡量使用internal目錄隔離不需要對外導(dǎo)出的功能。internal目錄約束在1.4版本中引入。
  • 隔離。隔離保證復(fù)雜功能布局下的可讀性,如cmd目錄。
  • 拆包。如果一個模塊的功能本身在一定程度上是完備的,可以考慮拆分。

以上就是Go模塊布局管理文檔翻譯理解的詳細內(nèi)容,更多關(guān)于Go模塊布局管理的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Gin使用swagger生成接口文檔的代碼示例

    Gin使用swagger生成接口文檔的代碼示例

    Swagger 是一個規(guī)范和完整的框架,用于生成、描述、調(diào)用和可視化 RESTful Web 服務(wù),它使用 YAML 或 JSON 格式來定義 API 的結(jié)構(gòu),本文給大家介紹了Gin使用swagger生成接口文檔的代碼示例,需要的朋友可以參考下
    2024-06-06
  • Golang自動追蹤GitHub上熱門AI項目

    Golang自動追蹤GitHub上熱門AI項目

    這篇文章主要為大家介紹了Golang自動追蹤GitHub上熱門AI項目,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • 使用golang引入外部包的三種方式:go get, go module, vendor目錄

    使用golang引入外部包的三種方式:go get, go module, ve

    這篇文章主要介紹了使用golang引入外部包的三種方式:go get, go module, vendor目錄,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 基于Go語言實現(xiàn)冒泡排序算法

    基于Go語言實現(xiàn)冒泡排序算法

    冒泡排序是交換排序中最簡單的一種算法。這篇文章將利用Go語言實現(xiàn)冒泡排序算法,文中的示例代碼講解詳細,對學(xué)習(xí)Go語言有一定的幫助,需要的可以參考一下
    2022-12-12
  • Golang二維切片初始化的實現(xiàn)

    Golang二維切片初始化的實現(xiàn)

    這篇文章主要介紹了Golang二維切片初始化的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 詳解如何使用Golang擴展Envoy

    詳解如何使用Golang擴展Envoy

    這篇文章主要為大家介紹了詳解如何使用Golang擴展Envoy實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • Go語言中g(shù)oroutine和WaitGroup的使用示例詳解

    Go語言中g(shù)oroutine和WaitGroup的使用示例詳解

    goroutine 是Go中一個輕量級的線程, 只需要一個go關(guān)鍵字就可以創(chuàng)建一個goroutine,這篇文章主要介紹了Go語言中g(shù)oroutine和WaitGroup的使用,需要的朋友可以參考下
    2023-03-03
  • Windows下在CMD下執(zhí)行Go出現(xiàn)中文亂碼的解決方法

    Windows下在CMD下執(zhí)行Go出現(xiàn)中文亂碼的解決方法

    在cmd下運行g(shù)o程序或者是GOLAND的Terminal下運行g(shù)o程序會出現(xiàn)中文亂碼的情況。本文就詳細的介紹下解決方法,具有一定的參考價值,感興趣的可以了解一下
    2021-12-12
  • go local history本地歷史恢復(fù)代碼神器

    go local history本地歷史恢復(fù)代碼神器

    這篇文章主要為大家介紹了go local history本地歷史恢復(fù)代碼神器的使用功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • golang獲取變量或?qū)ο箢愋偷膸追N方式總結(jié)

    golang獲取變量或?qū)ο箢愋偷膸追N方式總結(jié)

    在golang中并沒有提供內(nèi)置函數(shù)來獲取變量的類型,但是通過一定的方式也可以獲取,下面這篇文章主要給大家介紹了關(guān)于golang獲取變量或?qū)ο箢愋偷膸追N方式,需要的朋友可以參考下
    2022-12-12

最新評論