时间:2021-05-22
前言
本篇主要讲述Go语言的命名规范。优秀的代码必须具备良好的可读性,而可读性的关键即在于命名风格。
Go的函数、变量、常量、自定义类型、包(Package)的命名方式遵循以下规则:
1)首字符可以是任意的Unicode字符或者下划线
2)剩余字符可以是Unicode字符、下划线、数字
3)字符长度不限
Go只有25个关键字
break default func interface selectcase defer go map structchan else goto package switchconst fallthrough if range typecontinue for import return var优秀的命名
首条经验
声明位置与使用位置越远,则命名应当越长。
骆驼命名法
局部变量
参数
函数的参数和局部变量类似,但是它们默认还具有文档的功能
当参数类型具有描述性的时候,参数名就应该尽可能短小:
func AfterFunc(d Duration, f func()) *Timerfunc Escape(w io.Writer, s []byte)当参数类型比较模糊的时候,参数名就应当具有文档的功能:
func Unix(sec, nsec int64) Timefunc HasPrefix(s, prefix []byte) bool返回值
在Go语言中,返回值可以定义名称的,它可以当做一种特殊的参数。
尤其重要的是,在外部可见的函数中,返回值的名称应当可以作为文档参考。
func Copy(dst Writer, src Reader) (written int64, err error)func ScanBytes(data []byte, atEOF bool) (advance int, token []byte, err error)方法接收者(Receiver)
方法接收者也是一种特殊的参数。Go语言中没有明显的面向对象的概念,可以对方法定义方法接收者来实现类似于对象的方法的概念。
按照惯例,由于方法接收者在函数内部经常出现,因此它经常采用一两个字母来标识方法接收者的类型。
func (b *Buffer) Read(p []byte) (n int, err error)func (sh serverHandler) ServeHTTP(rw ResponseWriter, req *Request)func (r Rectangle) Size() Point需要注意的是,方法接收者的名字在同一类型的不同方法中应该保持统一,这也是前文所述的一贯性的需求。
导出包级别命名
导出名被使用的时候通常是放在包名后
所以,在导出变量、常数、函数和类型的时候,
不要把包名的意义再写一遍
比较好的名字
比较蠢的名字
接口类型
只含有一个方法的接口类型通常以函数名加上er后缀作为名字
type Reader interface { Read(p []byte) (n int, err error)}有时候可能导致蹩脚的英文,但别管他,能看懂就好
type Execer interface { Exec(p []byte) (n int, err error)}有时候可以适当调整一下英文单词的顺序,增加可读性:
type ByteReader interface { ReadByte(p []byte) (n int, err error)}当接口含有多个方法的时候,还是要选取一个能够精准描述接口目的的名字,譬如net.Conn、http/ResponseWriter
Error的命名
Error类型应该写成FooError的形式
type ExitError struct { ....}Error变量协程ErrFoo的形式
var ErrFormat = errors.New("unknown format")包的命名
应当与它导出代码的内容相关,避免util、common这种宽泛的命名
引入路径
包路径的最后一个单词应该和包名一致
包路径应该尽可能简洁
记得把库的主要代码直接放在代码库的根目录
避免在包路径中使用任何大写字母(并非所有文件系统都区分大小写)
标准库
上述很多例子都是从标准库中来的
标准库的很多内容都可以作为参考
多看看标准库来寻求灵感吧
但是要记住:
当作者写标准库的时候,他们自己也在学习过程中。
多数情况下作者是对的,但是偶尔还是会犯一些错误
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
参考文献
What's in a name? - Andrew Gerrand
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本篇不是教给大家如何去学习python,有需要详细深入学习的朋友可以参阅:Python基础语言学习笔记总结(精华)本文通过一周快速学习python入门知识总计了
说明:之前学习过go语言(大概是0.9版本),后来更新太快,也没怎么使用,就荒废掉了,今年有项目需要用go开发,重新捡起。这是我在学习go语言过程中整理的内容,
前言初识go语言不到半年,我是一次偶然的机会认识了golang这门语言,看到他简洁的语法风格和强大的语言特性,瞬间有了学习他的兴趣最近学习Go,但是苦于没有项目
本文实例讲述了JSP学习之JavaBean用法。分享给大家供大家参考。具体如下:JavaBean就是一种符合某些命名方法和设计规范的Java类JavaBean可
如果你从Ruby或者Python转型到Go,将会有很多语言差异需要学习,其中很多问题都是围绕处理string类型。下面是一些字符串的技巧,这些技巧解决了我在使用