imquanquan Translating Trying Other Go Versions ============================================================ While I generally use the current release of Go, sometimes I need to try a different version. For example, I need to check that all the examples in my [Guide to JSON][2] work with [both the supported releases of Go][3](1.8.6 and 1.9.3 at time of writing) along with go1.10rc1. I primarily use the current version of Go, updating it when new versions are released. I try out other versions as needed following the methods described in this article. ### Trying Betas and Release Candidates[¶][4] When [go1.8beta2 was released][5], a new tool for trying the beta and release candidates was also released that allowed you to `go get` the beta. It allowed you to easily run the beta alongside your Go installation by getting the beta with: ``` go get golang.org/x/build/version/go1.8beta2 ``` This downloads and builds a small program that will act like the `go` tool for that specific version. The full release can then be downloaded and installed with: ``` go1.8beta2 download ``` This downloads the release from [https://golang.org/dl][6] and installs it into `$HOME/sdk` or `%USERPROFILE%\sdk`. Now you can use `go1.8beta2` as if it were the normal Go command. This method works for [all the beta and release candidates][7] released after go1.8beta2. ### Trying a Specific Release[¶][8] While only beta and release candidates are provided, they can easily be adapted to work with any released version. For example, to use go1.9.2: ``` package main import ( "golang.org/x/build/version" ) func main() { version.Run("go1.9.2") } ``` Replace `go1.9.2` with the release you want to run and build/install as usual. Since the program I use to build my [Guide to JSON][9] calls `go` itself (for each example), I build this as `go` and prepend the directory to my `PATH` so it will use this one instead of my normal version. ### Trying Any Release[¶][10] This small program can be extended so you can specify the release to use instead of having to maintain binaries for each version. ``` package main import ( "fmt" "os" "golang.org/x/build/version" ) func main() { if len(os.Args) < 2 { fmt.Printf("USAGE: %v [commands as normal]\n", os.Args[0]) os.Exit(1) } v := os.Args[1] os.Args = append(os.Args[0:1], os.Args[2:]...) version.Run("go" + v) } ``` I have this installed as `gov` and run it like `gov 1.8.6 version`, using the version I want to run. ### Trying a Source Build (e.g., tip)[¶][11] I also use this same infrastructure to manage source builds of Go, such as tip. There’s just a little trick to it: * use the directory `$HOME/sdk/go` (e.g., `$HOME/sdk/gotip`) * [build as normal][1] * `touch $HOME/sdk/go/.unpacked-success` This is an empty file used as a sentinel to indicate the download and unpacking was successful. (On Windows, replace `$HOME/sdk` with `%USERPROFILE%\sdk`) -------------------------------------------------------------------------------- via: https://pocketgophers.com/trying-other-versions/ 作者:[Nathan Kerr ][a] 译者:[译者ID](https://github.com/译者ID) 校对:[校对者ID](https://github.com/校对者ID) 本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出 [a]:nathan@pocketgophers.com [1]:https://golang.org/doc/install/source [2]:https://pocketgophers.com/guide-to-json/ [3]:https://pocketgophers.com/when-should-you-upgrade-go/ [4]:https://pocketgophers.com/trying-other-versions/#trying-betas-and-release-candidates [5]:https://groups.google.com/forum/#!topic/golang-announce/LvfYP-Wk1s0 [6]:https://golang.org/dl [7]:https://godoc.org/golang.org/x/build/version#pkg-subdirectories [8]:https://pocketgophers.com/trying-other-versions/#trying-a-specific-release [9]:https://pocketgophers.com/guide-to-json/ [10]:https://pocketgophers.com/trying-other-versions/#trying-any-release [11]:https://pocketgophers.com/trying-other-versions/#trying-a-source-build-e-g-tip