在visual studio code 1.0发布之前我也曾多次尝试使用visual studio code开发Go程序,但是都放弃了,一是Go的插件还没发布或者不完善,而是vscode还不是那么方便,所以我一直使用atom + goplus + godebug编写Go的代码,而且用起来也非常的顺手方便。 现在vscode 1.0发布了,而且支持10种本地化语言,我尝试使用它编写Go程序,功能和性能都不错,所以目前atom和vscode都是我的菜。
本文简单介绍一下使用vscode开发Go的一些配置,速览vscode + Go 的功能。
vscode安装上后会根据你的操作系统的本地化设置来配置你的visual studio code采用的语言,所以很可能你安装上之后显示为简体中文。目前vscode 1.0支持下面 10种语言 :
我还是习惯于英语环境,所以调整本地化语言为英语。如果想调整语言,使用 "ctrl + shift + P"打开命令面板,输入 "Conf" 就会显示出 “Configure Language”命令,点击这个命令就会新建或者打开locale.json文件,在这个文件中你就可以设置你的locale 语言了:
{ "locale":"en-US"}
我把它改成英文显示,重启vscode就显示英文了。
要开发Go程序,你需要安装Go的插件。 "ctrl + shift + P"打开命名面板,然后输入 "ext install Go"就会安装Go插件了,安装完后提示你重启vscode,就可以编写Go程序了。
它支持以下功能:
它的调试功能值得称赞,Go总算也有一个方便的调试功能呢,加上断点后可以断点所在的堆栈信息,变量以及监控自定义的表达式。(atom + godebug也可以实现这个功能,它也通过delve进行调试)
在vscode左边工具栏的第四个图标就可以打开调试窗口,点击某行可以方便的在代码中增加断点。
当然,在第一次编写Go代码的时候,可能需要安装所需的工具,如guru、go-symbols、goreturns等。如果设置好GOPATH环境变量,启动vscode,打开一个go代码文件,在右下角你会看到 "Analysis Tools Missing"的提示,点击它就会自动安装这些所需的工具。你也可以手工安装它们:
go get -u -v github.com/nsf/gocodego get -u -v github.com/rogpeppe/godefgo get -u -v github.com/golang/lint/golintgo get -u -v github.com/lukehoban/go-outlinego get -u -v sourcegraph.com/sqs/goreturnsgo get -u -v golang.org/x/tools/cmd/gorenamego get -u -v github.com/tpng/gopkgsgo get -u -v github.com/newhook/go-symbolsgo get -u -v golang.org/x/tools/cmd/guru
vscode的Go插件有一些可以定制化的配置,你可以打开user preferences 或者 workspace settings来配置。如果想对所有的Go项目有效,就修改user preferences。
点击菜单 "File -> Preferences -> User Settting"打开窗口,左边的窗口是 vscode缺省配置,右边的窗口可以添加我们自己的设置。对于Go插件,可以添加如下的设置:
{ "go.buildOnSave": true, "go.lintOnSave": true, "go.vetOnSave": true, "go.buildFlags": [], "go.lintFlags": [], "go.vetFlags": [], "go.coverOnSave": false, "go.useCodeSnippetsOnFunctionSuggest": false, "go.formatOnSave": true, "go.formatTool": "goreturns", "go.goroot": "C:/Go", "go.gopath": "C:/gopath"}
它定制了Go插件的一些行为和变量。比如你可以改格式化工具为"gofmt",如 "go.formatTool": "gofmt"。
在写Go代码的时候,很多工具只有在编写的文件保存的时候才会执行,比如格式化,vet,lint、cover、test等,所以定时的保存文件可以触发这些动作,因此你可以在这个配置文件中加上下面的配置:
"files.autoSave": "afterDelay"
它可以定时的保存文件。
你可以通过菜单 "File -> Preferences -> Keyboard Shortcuts"查看和定义快捷键。左边的窗口显示缺省的快捷键设置,但是不是很直观,建议看这个 链接 ,它分门别类的介绍了每个快捷键的功能。
一般涉及到快捷键,我都会对其中的一个快捷键特别的关注,就是 "ctrl + space",这个键一般用来设置触发提示的功能,但是和输入法切换的快捷键冲突,所以我会重新定义它。在刚才打开的右边窗口中增加定义:
{ "key": "ctrl+j", "command": "editor.action.triggerSuggest", "when": "editorTextFocus"}
同时我还增加了一个自己习惯的快捷键,就是格式化代码的快捷点,默认设置为 "shift+alt+f",我新增加了一个快捷键:
{ "key": "ctrl+alt+f", "command": "editor.action.format", "when": "editorTextFocus" }
以及执行测试的快捷键
{ "key": "ctrl+alt+t", "command": "go.test.cursor", "when": "editorTextFocus"},{ "key": "ctrl+alt+p", "command": "go.test.package", "when": "editorTextFocus"}
右边窗口的的右下角有对话框可以帮助你增加快捷键,当然你也可以想我这样一样手工添加。
Go插件和vscode工具配合的很好,比如调用格式化代码的快捷键就可以进行格式化,不必在保存的时候就可以执行。你也可以在命令面板中输入 "!"查看警告和错误信息。
类似Sublime text,命令面板非常的有用, "ctrl + p"打开它后输入 "?"可以查看它的不同的功能。
vscode的状态栏也非常的有用,插件信息、git信息,文档信息都会在这里显示。
你可以改变代码高亮的风格。"ctrl + shift + P"打开命令面板,输入 "theme"会显示 "Preferences:Color Theme",点击它会显示可用的theme。 你还可以在 visual studio marketplace 上你可以找到更多的theme,比如我使用的[Seti Modified],和atom的保持一致。
相比atom,当然vscode还有不足的地方,比如打开多个文件,它们不会以tab的显示多窗口,你还需要"ctrl + tab"再选择其它的文件。没有安装Python但是还总提示Python插件需要升级等。但是也有比atom功能强大的地方,比如 "ctrl" +鼠标点击就可以查看方法的定义,性能可能比atom要好,尽管在我的机器上还没看出太大的性能区别。
本文只是粗略的展示了vscode和Go插件的功能,相信更强大的功能还有待在实践中发掘和学习。
转载请注明文章来源: colobu.com