本文是「vangoleo的Go語言學習筆記」系列文章之一。 官網: http://www.vangoleo.com/go/go-hello-world-02/html
往期回顧:git
上一篇文章Go語言入門:Hello world中,咱們在Golang Playground中體驗了Go語言,編寫並運行了一個簡單的Hello World,相信你們對Go語言的語法有了一些瞭解。github
學習一種編程語言,除了基本的語法,更重要的是要了解如何在實際的工程中使用它。本文中,我會和你們一塊兒,從零開始,安裝Go語言,配置環境,安裝IDE,開發一個Hello World程序。這個Hello World版我會編寫兩個版本:GOPATH和Go Module版本。golang
Q: 本教程爲何會編寫兩個版本? A: 網上大部分Go語言Hello World都只簡單地介紹了GOPATH版本。可是從Go的1.11版本以後,已再也不推薦使用GOPATH來構建應用了。也就是說GOPATH被認爲是廢棄的,錯誤的作法。 正確的作法是使用Go Module。因此,有必要在教程中將這個信息告訴初學者,引導你們使用推薦的最佳實踐方式Go Module。 或許這也是本Hello World教程和網上大部分教程的區別吧。會從開發者的實際使用出發。介紹Go語言的發展歷史和最佳實踐。編程
<!-- more -->bash
使用Go語言開發,第一步確定是安裝Go啦。框架
第一步:進入Go語言的官網https://golang.org。點擊「Download Go」。是的,就是那個傻傻的土撥鼠^_^ 第二步:根據操做系統下載對應的軟件包進行安裝。 Golang對主流的操做系統都有支持,好比Windows,MacOS和Linux等。 本系列教程中,我會使用MacOS操做系統,因此選擇下載「Apple macOS」。你們要根據本身的操做系統進行下載。 第三步:安裝Go。 在MacOS下安裝Go很簡單,就是標準的DMG文件安裝,直接「下一步」就能夠了。 第四步:確認Go是否安裝成功。 運行命令「go version」,會輸出相似於「go version go1.12.9 darwin/amd64」的內容。請確保包沒有任何錯誤發生。編程語言
和其餘開發語言相似,安裝了Go以後,還須要對開發環境進行相應的配置。好比在Java中,須要配置JAVA_HOME,MAVEN等。 Go開發相關的環境變量以下:編輯器
GOROOT是Go的安裝路徑。Mac中安裝Go會自動配置好GOROOT,路徑爲/usr/local/go
。GOROOT在絕大多數狀況下都不須要修改。如下是GOROOT目錄的內容(已省略了一些無關信息):工具
tree -L 2 /usr/local/go ./ ├── bin │ ├── go │ └── gofmt ├── doc │ ├── articles │ └── docs.html ├── src │ ├── errors │ ├── fmt │ ├── log │ └── os
能夠看到GOROOT下有bin,doc和src目錄。bin目錄下有咱們熟悉的go和gofmt工具。能夠認爲GOOROOT和Java裏的JDK目錄相似。
GOPATH是開發時的工做目錄。用於:
go get
和go install
命令會下載go代碼到GOPATH。關於GOPATH須要特別注意。在GO的1.11版本以前,GOPATH是必需的,且全部的Go項目代碼都要保存在GOPATH目錄下。Go的1.11版本以後,GO官方引入了Go Module。使用Go Module管理的項目能夠放在GOPATH目錄外面。
使用GOPATH時,GO會在如下目錄中搜索包:
GOROOT/src
:該目錄保存了Go標準庫代碼。GOPATH/src
:該目錄保存了應用自身的代碼和第三方依賴的代碼。假設程序中引入了以下的包:
import "github.com/tom/hello-go/foo/bar"
第一步:Go會先去GOROOT的scr目錄中查找,很顯然它不是標準庫的包,沒找到。 第二步:繼續在GOPATH的src目錄去找,準確說是GOPATH/src/github.com/tom/hello-go/foo/bar
這個目錄。若是該目錄不存在,會報錯找不到package。在使用GOPATH管理項目時,須要按照GO尋找package的規範來合理地保存和組織Go代碼。
Go的這個「將全部代碼都放置在GOPATH中」的設計,的確是和其餘主流語言很不同。無論Go官方是出於什麼考慮,這個設計在實際使用中,的確給開發者形成了很大的不便和理解上的困難。甚至直接勸退了不少Go的初學者。 萬幸的是,Go Module正式發佈了。Go Module的發佈解決了困擾Go語言長達十年的代碼組織,依賴管理問題。
說明:關於GOPATH和Go Module的歷史淵源,詳細使用,會在另外一篇進行說明。本文仍是聚焦在Hello World入門。
另外,因爲某些緣由,Go的某些託管在Google倉庫中的代碼在國內是沒法訪問的。若是使用Go Module,咱們能夠設置GOPROXY,讓Go從GOPROXY下載Go代碼,速度更快。國內用戶能夠設置GOPROXY爲https://goproxy.cn,使用以下命令來設置GOPROXY:
export GOPROXY=https://goproxy.cn
關於環境配置,總結下來就是:
目前比較經常使用的IDE有:
Visual Studio Code是微軟開發的一款開源的,輕量級的文本編輯器。經過安裝Go插件,能夠用於Go語言的開發。GoLand是JetBrains公司開發的,專業的Go語言開發IDE。
推薦使用GoLand。不少人都說Visual Studio Code更輕量級,但做爲一款天天都要重度使用的,須要靠它吃飯的工具,咱們須要的是功能全面。尤爲是當你須要完備的調試,須要強大的IDE智能輔助功能時,相信你會選擇更專業的GoLand。
GoLand的官方主頁爲https://www.jetbrains.com/go/,點擊「Download」便可下載
注意 GoLand使用的是和IntelliJ IDEA同樣的框架,是用Java語言開發的。你須要安裝Java環境才能夠運行GoLand哦。
GoLand是收費軟件,只有30天的試用期。試用期結束後,須要購買受權。固然在天朝,咱們都習慣不花錢用軟件。你們能夠自行百度或google搜索一下。
第一步:設置GOPATH 首先設置GOPATH,假設GOPATH設置爲$HOME/worspace/go
。 第二步:建立子目錄 進入$HOME/workspace/go
目錄。新建子目錄src。而後再src中新建子目錄hello。在hello目錄,新建一個hello-world.go文件: 目錄結構應該以下所示:
$HOME workspace go src hello hello-world.go
第三步:建立hello-world.go文件:
package main import "fmt" func main() { fmt.Println("hello world") }
第四步:執行go build 在$HOME/workspace/go
目錄執行命令:
go build
會生成一個可執行二進制文件:hello。若是是Windows系統,會生成hello.exe文件。 第五步:運行hello文件:
./hello hello world
輸出「hello world」。
第一步:建立項目的根目錄 任意建立一個目錄(能夠不在GOPATH中),假設是$HOME/tmp/hello。 第二步:初始化Go模塊 執行命令:
go mod init github.com/vangoleo/hello
該命令會將hello目錄初始化爲一個Go module,並生成一個$HOME/tmp/hello/go.mod
文件。內容以下:
module github.com/vangoleo/hello go 1.12
第三步:編寫hello.go文件 編寫文件$HOME/tmp/hello/hello.go
:
package main import ( "fmt" "rsc.io/quote" ) func main() { fmt.Println(quote.Hello()) }
第四步:編輯go.mod文件: 在實際項目中,都會使用到第三方庫。能夠在Go Module中添加項目的依賴。本例中,咱們會添加一個quote依賴,該依賴會打印當前語言的「Hello World」,好比,若是是中文環境,會打印「你好,世界」。 編輯go.mod文件,添加quote依賴:
module github.com/vangoleo/hello go 1.12 require rsc.io/quote v1.5.2
第五步:執行go build 執行go build,會生成可執行文件$HOME/tmp/hello/hello
。 第六步:執行hello文件 執行hello文件,輸出「你好,世界」。
本文中,咱們從下載安裝,配置Go環境開始,並完成了GOPATH和Go Module兩個版本的Hello World應用。若是你跟着我一步一步完成了這些步驟,恭喜你!!!已經完成了第一個真正的Go應用,而且使用了正確的Go Module來管理Go程序。
接下來,咱們能夠開始學習Go語言的語法部分(基本數據類型,判斷,循環等)了。咋們下期見。
本文由 www.vangoleo.com 發佈