Go语言注释的定义及使用(godoc工具提取注释内容)
在讲解Go语言注释之前,大家可以先来看一下下面这段代码。
注释不会被编译,但可以通过 godoc 来获取。
Go语言中注释一般分为两种,分别是单行注释和多行注释:
每一个包都应该有相关注释,上述代码中在 package 语句之前的注释内容将被默认认为是这个包的文档说明,其中应该提供一些相关信息并对整体功能做简要的介绍,一个包可以分散在多个文件中,但是只需要对其中一个进行注释说明即可。
当开发人员需要了解包的一些情况时,自然会用 godoc 来显示包的文档说明。在首行的简要注释之后可以用成段的注释来进行更详细的说明,而不必拥挤在一起。另外,在多段注释之间应以空行分隔加以区分,如下所示:
godoc 工具一般有以下几种用法:
godoc 工具只能获取在 Go 安装目录下 ../go/src 中的注释内容,此外,它还可以作为一个本地文档浏览 web 服务器,在命令行输入
此外 godoc 也可以用于生成非标准库的 Go 源码文件的文档注释。
//test.go package main import "fmt" // 引入 fmt 包 func main() { fmt.Printf("Καλημέρα κόσμε; or こんにちは 世界\n") }上面这个例子通过打印“Καλημέρα κόσμε; or こんにちは 世界”展示了如何在Go语言中使用国际化字符,以及如何使用注释。
注释不会被编译,但可以通过 godoc 来获取。
Go语言中注释一般分为两种,分别是单行注释和多行注释:
-
单行注释是最常见的注释形式,可以在任何地方使用以
//
开头的单行注释; -
多行注释也叫块注释,均已以
/*
开头,并以*/
结尾,且不可以嵌套使用,多行注释一般用于包的文档描述或注释成块的代码片段。
每一个包都应该有相关注释,上述代码中在 package 语句之前的注释内容将被默认认为是这个包的文档说明,其中应该提供一些相关信息并对整体功能做简要的介绍,一个包可以分散在多个文件中,但是只需要对其中一个进行注释说明即可。
当开发人员需要了解包的一些情况时,自然会用 godoc 来显示包的文档说明。在首行的简要注释之后可以用成段的注释来进行更详细的说明,而不必拥挤在一起。另外,在多段注释之间应以空行分隔加以区分,如下所示:
// Package superman implements methods for saving the world. // // Experience has shown that a small number of procedures can prove // helpful when attempting to save the world. package superman几乎所有全局作用域的类型、常量、变量、函数和被导出的对象都应该有一个合理的注释,如果这种注释(称为文档注释)出现在函数前面,例如函数 Abcd,则要以 "Abcd..." 作为开头,如下所示:
// enterOrbit causes Superman to fly into low Earth orbit, a position // that presents several possibilities for planet salvation. func enterOrbit() error { ... }
godoc 工具
godoc 工具会从 Go 程序和包文件中提取顶级声明的首行注释以及每个对象的相关注释,并生成相关文档,也可以作为一个提供在线文档浏览的 web 服务器,Go语言官网(https://golang.google.cn/)就是通过这种形式实现的。godoc 工具一般有以下几种用法:
-
go doc package:获取包的文档注释,例如
go doc fmt
会显示使用 godoc 生成的 fmt 包的文档注释; -
go doc package/subpackage:获取子包的文档注释,例如
go doc container/list
; -
go doc package function:获取某个函数在某个包中的文档注释,例如
go doc fmt Printf
会显示有关 fmt.Printf() 的使用说明。
godoc 工具只能获取在 Go 安装目录下 ../go/src 中的注释内容,此外,它还可以作为一个本地文档浏览 web 服务器,在命令行输入
godoc -http=:6060
,然后使用浏览器打开 http://localhost:6060 后,就可以看到本地文档浏览服务器提供的页面。此外 godoc 也可以用于生成非标准库的 Go 源码文件的文档注释。
所有教程
- socket
- Python基础教程
- C#教程
- MySQL函数
- MySQL
- C语言入门
- C语言专题
- C语言编译器
- C语言编程实例
- GCC编译器
- 数据结构
- C语言项目案例
- C++教程
- OpenCV
- Qt教程
- Unity 3D教程
- UE4
- STL
- Redis
- Android教程
- JavaScript
- PHP
- Mybatis
- Spring Cloud
- Maven
- vi命令
- Spring Boot
- Spring MVC
- Hibernate
- Linux
- Linux命令
- Shell脚本
- Java教程
- 设计模式
- Spring
- Servlet
- Struts2
- Java Swing
- JSP教程
- CSS教程
- TensorFlow
- 区块链
- Go语言教程
- Docker
- 编程笔记
- 资源下载
- 关于我们
- 汇编语言
- 大数据
- 云计算
- VIP视频