我是一名新的golang开发人员,我想知道为什么$GOPATH需要在项目的根目录设置环境变量。
$GOPATH
如果我同时从事多个项目,则每次都需要重新设置$GOPATH环境变量以指向不同的位置。
在我的设置中,我已$GOPATH设置为/Users/Projects/go/lib。这是我所有golang项目的通用目录。
/Users/Projects/go/lib
只是为了澄清:将项目数据放入 /Users/Projects/go/<Project Name>
/Users/Projects/go/<Project Name>
如果$GOPATH(据我所知)全部用于安装第三方库,那么$GOPATH为我所有的项目提供一个目录并不安全,因此所有必需的第三方库都安装在同一lib目录中,并且每当我在项目上进行编译时,它只会使用所需的库。
在实践中这不好吗?为什么?
(2018年第二季度: 请注意,对于 vgo项目 ,GOPATH可能最终不赞成使用基于项目的工作流。这样可以避免GOPATH两年前我在下面提出的基于手动项目的建议)
GOPATH
使用Go 1.11(2018年8月), GOPATH 可以是可选的,带有modules。
VSCode越来越支持它:
2016年6月:您不必 仅 依赖一个GOPATH(即一个工作区)。
我的全部GOPATH内容包括:
goimports
github.com/smartystreets/goconvey
$HOME/go
src
pkg
bin
这是两条路径:
export GOPATH=/path/to/myproject:$HOME/go
为我的所有项目都拥有一个$ GOPATH目录是不安全的,因此所有必需的第三方库都安装在同一个lib目录中,并且每当我编译项目时,它都将使用所需的库。 在实践中这不好吗?为什么?
为我的所有项目都拥有一个$ GOPATH目录是不安全的,因此所有必需的第三方库都安装在同一个lib目录中,并且每当我编译项目时,它都将使用所需的库。
我不喜欢这种做法,因为不同的项目可能需要同一个库的不同 版本 。 这就是为什么GOPATH每个项目都有一个,我的构建脚本(随项目版本化)为我设置的原因。
当我克隆我的go项目时,我:
vendor
<myproject>/src/<myproject> -> ../..
myproject
src/<apackage>
该组织:
go get
我有:
myproject mysource.go apackage othersource.go src myproject -> ../.. vendor third-party packages
在Windows上,典型的构建脚本为:
λ more b.bat @echo off setlocal EnableDelayedExpansion if not defined GOROOT ( echo Environment variable GOROOT must be defined, with %%GOROOT%%\bin\go.exe exit /b 1 ) set PATH=C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem set PATH=%PATH%;%GOROOT%/bin set GOPATH=%~dp0;%HOME%/go set prjname=%GOPATH:~0,-1% for %%i in ("%prjname%") do set "prjname=%%~ni" rem echo prjname='%prjname%' if not exist src ( mkdir src ) if not exist src\%prjname% ( mklink /J src\%prjname% %GOPATH% ) pushd %~dp0 cd src\%prjname% rem cd go install popd endlocal
克隆我的go项目的任何人都只需键入“ b”。
b