一. 命令规范

1、包命名:package

保持package的名字和目录保持一致,尽量采取有意义的包名,简短,有意义,尽量和标准库不要冲突。包名应该为小写单词,不要使用下划线或者混合大小写。

2、文件命名

尽量采取有意义的文件名,简短,有意义,应该为小写单词,使用下划线分隔各个单词。

非单元测试文件不要以_test结尾,go编译器默认x_test.go为单元测试文件,不会进行编译。

3、变量命令

采用驼峰法,通过首字母大小写来控制是否包外可见

接口命名

  • 单个函数的接口名以"er"作为后缀,例如type Reader interface {…}
  • 两个函数的接口名综合两个函数名,例如type WriteFlusher interface {…}
  • 三个以上函数的接口名,类似于结构体名,例如type Car interface {…}

特殊名词的首字母缩写需要按照规范来,例如URLProxy或者urlProxy不要命名为UrlProxy。

二. 格式化

Goland 推荐使用插件 save actions,其他IDE 使用gofmt,goimports


三. 注释

多写关键函数的注释,活用//TODO,//FIXME


四. 包引入

1、如果你的包引入了三种类型的包,标准库包,程序内部包,第三方包,建议采用如下方式进行组织你的包


2、在项目中不要使用相对路径引入包,使用绝对路径引入包

3、不要使用 . 来省略包名引用


五.缩进

为了保证最小的代码缩进和代码可读性,有一些缩进的规范,如下所示

六.其他

func (c *Client) GetUserName() string

2、每行代码长度最好不超过80个字符,如果超过建议换行

3、函数返回值采用返回"指针"类型而不是返回"值"类型 (推荐但不强制

4、错误处理的原则是不能忽略任何error,不要使用"_"丢弃,必须全部处理。接收到错误,要么返回error给上层调用,要么使用log打印对应的error和warn信息 (强制

5、没十分必要不能panic,进程开始的处理函数可以panic

6、任何一个goroutine都应该有recover来保护程序不会因为panic而crash,因为任何一个goroutine如果抛panic但没有recover整个程序会crash

7、注意闭包的使用,在循环中调用函数或者goroutine方法,一定要采用显示的变量调用,不要再闭包函数里面调用循环的参数