本文介绍 Windows7 x64 基于 IntelliJ IDEA 搭建 Go 语言开发环境。主要是一些操作过程截图以及简单文字描述,如有不清楚的地方​,欢迎指正。所有软件使用当前(2016.12.02)最新版本,旧版或新版可能存在细微差异。

一、网络代理软件 cntlm

从 这里 下载最新 0.92.3 版本 cntlm。cntlm 作用是方便在 Windows 下执行 go get 。参照以下注意事项,并保留监听端口为默认的 3128,其它具体安装及配置参考《cntlm内网代理的代理》。

注意事项:

确保 cntlm.ini 有以下这些配置项

Username <工号>

Domain china

Auth NTLM

PassNT <按实际配置>

PassLM <按实际配置>

Proxy XXXX:8080

NoProxy localhost, 127.0.0., 10., 192.168.*

Listen 3128

必须安装在默认路径 C:\Program Files (x86)\Cntlm,非默认路径会有 问题

Windows 下的 cntlm 服务不稳定,有时需手动重启下服务恢复,原因未知。我在桌面创建了一个cntlm.bat,如果网络访问有问题,执行 cntlm.bat 重启下服务(可以考虑将 cntlm 放在 Linux 或 docker 中运行,服务会比较稳定。我就把 cntlm 放在 docker 中运行,如果你已有 docker 环境,可以找我要镜像)。

cntlm.bat 文件内容如下:

net stop cntlm

net start cntlm

安装配置后,记得启动服务,可直接运行 cntlm.bat

二、Go 1.7.4

下载 go1.7.4.windows-amd64.msi,保留默认安装路径(C:\Go\),一路 Next 。

配置环境变量(右击 计算机 -> 高级系统设置 -> 高级 -> 环境变量):

添加环境变量 GOPATH ,值为 D:\Codes\go

将 D:\Codes\go\bin 添加到 PATH,方便执行其目录下的程序

三、Git v2.11.0.windows.1

下载 64-bit Git for Windows Setup,保留默认安装路径(C:\Program Files\Git)及所有默认配置,一路 Next。

打开 Git Bash(在桌面右击鼠标 -> Git Bash here),执行 Git 基本配置:

用户和邮箱

git config --global user.name XXXX

git config --global user.email XXXX

支持长路径

git config --global core.longpaths true

导出和提交时不做文本格式转换

git config --global core.autocrlf false

配置网络代理,使用上面 cntlm 服务

git config --global http.proxy 127.0.0.1:3128

不校验ssl证书

git config --global http.sslVerify false

四、Go 命令行工具

这篇文章 提到 10+ 个命令行工具,其中比较有用的是 goimports 和 golint,以下以安装这两个工具为例,如需安装其它工具,操作步骤类似。

golang.org/x 仓库即使 FQ 也访问不了,一般做法是从 GitHub 镜像仓库下载,放置在 golang.org/x 对应路径,再执行安装。Git Bash 中执行:

安装 goimports

export GOPATH="D:\Codes\go"

git clone https://github.com/golang/tools.git $GOPATH/src/golang.org/x/tools

go install golang.org/x/tools/cmd/goimports

使用 go get 安装 golint(依赖上一步下载的 golang.org/x/tools 包)

go get -v github.com/golang/lint/golint

如果执行失败,排查上述操作步骤并重启 cntlm 服务,打开一个新的 Git Bash 试试;执行成功会生成两个可执行程序(后面 File Watchers 插件会用到)。

注:开发过程,依赖 GitHub 的包,也可以使用 go get 下载。

五、IntelliJ IDEA 2016.3

下载 IntelliJ IDEA 免费版,保留默认安装路径,一路 Next。

安装后,运行 IDEA:

如果之前安装过旧版本,继承之前配置选择第1项;否则默认第2项即可

选择自己喜欢的皮肤,其它一路 Next

六、安装 IDEA 插件

6.1 访问插件仓库需要配置网络代理(安装完插件后,可以去掉配置)

碰到这样的对话框一律"Accept"

或者勾选以下复选框

6.2 搜索并安装 Go 和 File Watchers,2个插件安装完后重启 IDEA

6.3 配置 Go 插件

6.4 创建 hello 工程

工程路径没有要求,建议先放在 D:\Codes\go\src\hello

注意:.idea 和 hello.iml 由 IDEA 自动生成和管理,不要手工修改。

创建 go 源文件 main.go

写一段简单代码,验证运行是否正常

运行结果

6.5 配置 File Watchers 插件

File Watchers 是工程级别的设置,所以要在上一步工程的基础上操作

File -> Settings... -> Tools -> File Watchers

-w $FilePath$

-set_exit_status $FilePath$

将File Watchers 配置导出,保存在用户 home 目录下

以后创建新工程,直接导入该配置,避免重复配置(点第1个按钮切换到用户 home 目录)

编辑 .go 文件后保存,goimports 会对代码进行格式化(这里仅缩进对齐)

格式化后效果如下

golint 会检查编程风格(这里提示变量名不要使用下划线)

七、IDEA 使用

7.1 运行配置

已存在一个配置项 "Build main.go and run"(这是刚才执行运行生成的)

点击左上角 "+" 按钮,可以创建新的运行配置

配置项命名为 hello,以 Package 方式运行 hello 包,可执行程序存放目录、运行目录设置为 D:\Codes\go\bin

下拉框选择 hello,点击执行按钮

生成的可执行文件放置到指定输出目录

7.2 调试

鼠标左击编辑框行号位置,可以打断点,点击调试按钮启动调试

IDEA 使用了 Go 插件自带的 delve 工具进行调试

点击 "Debugger" 标签页可以查看调用栈,变量等信息

7.3 libraries 设置

IDEA 的 Go 工程默认会加载 GOPATH 环境变量,GOPATH 可以配置多个目录,允许代码分散在多个目录中。

关于如何组织代码,是个持续争论的话题...

虽然代码组织方式灵活,但也存在麻烦。在版本控制系统(svn,git)中,如果代码分散在多个地方,很容易漏提交 -- 自己环境上能够运行的工程,遗漏提交其它目录下的依赖包,别人导出的代码运行不了。一种方法是不使用 GOPATH,依赖包通过 vendor 机制和代码放在唯一目录下,也提交到版本库,IDEA 工程仅添加版本库导出目录(bin/pkg/src的父目录)到 "Project libraries"。

八、IDEA 的一些设置

从 File -> Settings... 打开设置窗口

不打开上次工程

Appearance & Behavior -> System Settings

去掉 Startup/Shutdown -> Reopen last project on startup

退出时不需确认

Appearance & Behavior -> System Settings

去掉 Startup/Shutdown -> Confirm application exit

去掉拼写检查

Editor -> Inspections

去掉 Spelling -> Typo

显示行号

Editor -> General -> Appearance

勾选 Show line numbers

编辑器字体

Editor -> Colors & Fonts -> Fonts

控制台字体

Editor -> Colors & Fonts -> Console Fonts

换行符

Editor > Code Style

Line Separator (for new files),最好设置为 Unix and OSX(\n)

缩进格式

Editor -> Code Style -> Go

终端

Tools -> Terminal

Shell Path 设置为 "C:\Program Files\Git\bin\bash.exe" --login -i

Git Bash 提供比 cmd.exe 多得多的功能,墙裂建议将终端设置为 Git Bash,开发过程可以在其中执行很多命令!

遗留:

IDEA 还支持 MacOS 和 Linux,通过 X Server 能够在 Windows 远程运行 Linux IDEA,​方便调试 Linux 上的代码,后续再补充。

参考阅读

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。