Go 言語では、「go build」コマンドは主にコードのコンパイルに使用されます。Go 言語のプログラム コードはバイナリ実行可能ファイルにコンパイルできますが、バイナリ ファイルは手動で実行する必要があります。 go build には、パラメータなしのコンパイル、ファイルリストのコンパイル、パッケージを指定したコンパイルなど、さまざまなコンパイル方法があり、これらの方法を使用して実行ファイルを出力できます。
このチュートリアルの動作環境: Windows 7 システム、GO バージョン 1.18、Dell G3 コンピューター。
Go 言語はコンパイルされた静的言語 (C 言語と同じ) であるため、Go 言語プログラムを実行する前に、バイナリ実行可能ファイルにコンパイルする必要があります。
Go 言語プログラムは、Go 言語が提供する go build
または go run
コマンドを使用してコンパイルできます。
go build
コマンドは Go 言語プログラム コードをバイナリ実行可能ファイルにコンパイルできますが、バイナリ ファイルを手動で実行する必要があります。
go run
コマンドの方が便利です。コンパイル直後に Go 言語プログラムを実行します。コンパイル プロセス中に一時ファイルが生成されますが、実行可能ファイルは生成されません。この機能はプログラムのデバッグに非常に適しています。
go build コマンド (go 言語のコンパイル コマンド)
Go 言語で使用される go build コマンドが主に使用されますコンパイルコード用。パッケージのコンパイル プロセス中に、必要に応じて、それに関連付けられたパッケージが同時にコンパイルされます。
go build にはパラメータなしのコンパイル、ファイルリストのコンパイル、指定したパッケージのコンパイルなど、多くのコンパイル方法があります。これらの方法を使用して実行可能ファイルを出力できます。
go build パラメータなしのコンパイル
このセクションで必要なコードの具体的な場所は、./src/chapter11/gobuild
です。
GOPATH に対するコードのディレクトリ関係は次のとおりです:
. └── src └── chapter11 └── gobuild ├── lib.go └── main.go
main.go コードは次のとおりです:
package main import ( "fmt" ) func main() { // 同包的函数 pkgFunc() fmt.Println("hello world") }
lib.go コードは次のとおりです:
package main import "fmt" func pkgFunc() { fmt.Println("call pkgFunc") }
ソース コードに GOPATH に依存するパッケージ参照がない場合、これらのソース コードはパラメーターなしの go build を使用できます。形式は次のとおりです。
go build
次に示すように、コードが配置されているディレクトリ (./src/chapter11/gobuild
) で go build コマンドを使用します。
go build ファイル リスト
同じディレクトリ内の複数のソース コード ファイルをコンパイルする場合、go build 後に複数のファイル名を指定できます。 build はこれらのソース コードをコンパイルし、実行可能ファイルを出力します。「go build ファイル リスト」の形式は次のとおりです:$ cd src/chapter11/gobuild/ $ go build $ ls gobuild lib.go main.go $ ./gobuild call pkgFunc hello world
go build file1.go file2.go……
go build file list」メソッドを使用してコンパイルする場合、実行可能ファイルはファイル内の最初のソース コード ファイルを選択します。デフォルトでは list を実行可能ファイル名として出力します。
-o パラメーターを使用できます。以下の例を参照してください。
$ go build main.go lib.go $ ls lib.go main main.go $ ./main call pkgFunc hello world $ go build lib.go main.go $ ls lib lib.go main main.go
-o myexec パラメータが挿入され、指定された出力ファイル名が myexec であることを示します。
go build file list」メソッドは、ファイル数が少ない Go 言語で書かれたツールに適しています。
go build package
GOPATH を設定した後、パッケージ内のファイルが追加された場合でも、「go build package」はパッケージ名に基づいて直接コンパイルできます (追加)または削除(例外)は、コンパイル ディレクティブには影響しません。 1) コードの場所とソース コード本小节需要用到的代码具体位置是./src/chapter11/goinstall。
本套教程所有源码下载地址:https://pan.baidu.com/s/1ORFVTOLEYYqDhRzeq0zIiQ 提取密码:hfyf
相对于GOPATH的目录关系如下:
. └── src └── chapter11 └──goinstall ├── main.go └── mypkg └── mypkg.go
main.go代码如下:
package main import ( "chapter11/goinstall/mypkg" "fmt" ) func main() { mypkg.CustomPkgFunc() fmt.Println("hello world") }
mypkg.go代码如下:
package mypkg import "fmt" func CustomPkgFunc() { fmt.Println("call CustomPkgFunc") }
2) 按包编译命令
执行以下命令将按包方式编译 goinstall 代码:
$ export GOPATH=/home/davy/golangbook/code $ go build -o main chapter11/goinstall $ ./goinstall call CustomPkgFunc hello world
代码说明如下:
第 1 行,设置环境变量 GOPATH,这里的路径是笔者的目录,可以根据实际目录来设置 GOPATH。
第 2 行,-o执行指定输出文件为 main,后面接要编译的包名。包名是相对于 GOPATH 下的 src 目录开始的。
第 3~5 行,编译成功,执行 main 后获得期望的输出。
go build 编译时的附加参数
go build 还有一些附加参数,可以显示更多的编译信息和更多的操作,详见下表所示。
附加参数 | 备 注 |
---|---|
-v | 编译时显示包名 |
-p n | 开启并发编译,默认情况下该值为 CPU 逻辑核数 |
-a | 强制重新构建 |
-n | 打印编译时会用到的所有命令,但不真正执行 |
-x | 打印编译时会用到的所有命令 |
-race | 开启竞态检测 |
表中的附加参数按使用频率排列,读者可以根据需要选择使用。
以上がGo言語でbuildコマンドを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。