我是一个新的golang开发人员,我想知道为什么$GOPATH需要在我的项目的根目录设置环境变量.
如果我同时处理几个项目,我每次都需要重新设置$GOPATH环境变量以指向不同的位置.
在我的设置中,我已经$GOPATH设置为/Users/Projects/go/lib.这是我所有golang项目的通用目录.
只是为了澄清:项目数据被放入 /Users/Projects/go/<Project Name>
如果无论如何所有$GOPATH用于(据我所知)是安装第三方库,为$GOPATH我的所有项目都有一个目录是不安全的,所以所有必需的第三方库都安装在同一个lib目录中,并且每当我编译项目时,它只使用它所需的库.
这在练习中是不是很糟糕?为什么?
(2018年第二季度:
请注意,对于vgo项目,GOPATH最终可能会弃用以支持基于项目的工作流程.这将避免GOPATH我在两年前提出的基于项目的手动建议)
使用Go 1.11(2018年8月),GOPATH可以选配模块.
VSCode越来越支持它:
2016年6月:您不必仅依赖一个GOPATH(即一个工作区).
我的全部GOPATH包括:
goimports),github.com/smartystreets/goconvey...),在$HOME/go例如,src,pkg也bin将是.这是两条路:
export GOPATH=/path/to/myproject:$HOME/go
Run Code Online (Sandbox Code Playgroud)
为我的所有项目安装一个$ GOPATH目录是不安全的,因此所有必需的第三方库都安装在同一个lib目录中,每当我编译项目时,它只使用它所需的库.
这在练习中是不是很糟糕?为什么?
我不喜欢这种做法,因为不同的项目可能需要不同版本的同一个库.
这就是为什么我GOPATH每个项目都有一个,我的构建脚本(用项目版本化)为我设置.
当我克隆我的go项目时,我:
GOPATH设置为该项目(本地路径,将安装该项目所需的第三方库,并移动到vendor文件夹),<myproject>/src/<myproject> -> ../..,因为GOPATHgo期望找到myprojectin 的来源src/<apackage>.该组织:
go get,GOPATH.我有:
myproject
mysource.go
apackage
othersource.go
src
myproject -> ../..
vendor
third-party packages
Run Code Online (Sandbox Code Playgroud)
在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
Run Code Online (Sandbox Code Playgroud)
任何克隆我的go项目的人都会输入' b'.
| 归档时间: |
|
| 查看次数: |
601 次 |
| 最近记录: |