Golang的short variable declaration

Go中,常规声明方式为

var i, j int

也有一种短的方式

i, j := 1, 2

这种方式相当于

var i, j int
i, j = 1, 2

但是短的方式允许重复声明,条件是必须有一个以上重复

i, j := 1, 2
z, j := 3, 4
i, j := 5, 6 // 报错!

我们来看一段代码:

package main

import (
	"fmt"
	"os"
)

var cwd string

func init() {
	cwd, err := os.Getwd()
	if err != nil {
		fmt.Printf("error = %s\n", err)
	}

	fmt.Printf("init: cwd = %s\n", cwd)
}

func main() {
	fmt.Printf("main: cwd = %s\n", cwd)
}

运行结果:

jiajun@debian $ go run fun.go
init: cwd = /home/jiajun/test
main: cwd =

为什么cwd明明已经声明成了全局变量却没有被没改变呢?

https://golang.org/ref/spec#Short_variable_declarations

Unlike regular variable declarations, a short variable declaration may redeclare variables provided they were originally declared earlier in the same block (or the parameter lists if the block is the function body) with the same type, and at least one of the non-blank variables is new.

所以上面的代码想要能正常运行就得:

package main

import (
	"fmt"
	"os"
)

var cwd string

func init() {
    var err error
	cwd, err = os.Getwd()
	if err != nil {
		fmt.Printf("error = %s\n", err)
	}

	fmt.Printf("init: cwd = %s\n", cwd)
}

func main() {
	fmt.Printf("main: cwd = %s\n", cwd)
}

更多文章
  • etcd源码阅读与分析(四):lease
  • 干了这碗叔本华牌毒鸡汤 --- 《人生的智慧》
  • Memory leak in net/http
  • etcd源码阅读与分析(三):wal
  • etcd源码阅读与分析(二):raft
  • etcd源码阅读与分析(一):raftexample
  • 虚拟机里的Ubuntu sudo时卡住
  • Raft论文阅读笔记
  • Go访问私有变量
  • 避免全局变量
  • Go的unsafe包
  • Golang中实现禁止拷贝
  • 人生如戏,全靠演技 -- 《日常生活中的自我呈现》读后感
  • Golang的反射
  • 数据库事务