golang怎么获取注释内容

golang中,可以使用godoc工具来提取注释内容。godoc工具会从Go程序和包文件中提取顶级声明的首行注释以及每个对象的相关注释,并生成相关文档,也可以作为一个提供在线文档浏览的web服务器。

golang怎么获取注释内容

本教程操作环境:windows10系统、GO 1.18版本、Dell G3电脑。

在golang中,可以使用godoc工具来提取注释内容。

godoc工具

godoc 工具会从 Go 程序和包文件中提取顶级声明的首行注释以及每个对象的相关注释,并生成相关文档,也可以作为一个提供在线文档浏览的 web 服务器,Go语言官网(https://golang.google.cn/)就是通过这种形式实现的。

立即学习“go语言免费学习笔记(深入)”;

需要注意:Go语言 1.13 版本移除了 godoc 工具,大家可以通过go get 命令来获取 godoc 工具。

go get golang.org/x/tools/cmd/godoc

登录后复制

由于防火墙的原因,国内的用户可能无法通过go get 命令来获取 godoc 工具,这时候就需要大家来手动操作了。

首先从 GitHub(https://github.com/golang/tools.git) 下载 golang.org/x/tools 包;

然后将下载得到的文件解压到 GOPATH 下的 srcgolang.orgxools 目录中,没有的话可以手动创建;

打开 GOPATH 下的 srcgolang.orgxoolscmdgodoc 目录,在该目录下打开命令行工具,并执行go build 命令,生成 godoc.exe 可执行文件;

最后,将生成的 godoc.exe 文件移动到 GOPATH 下的 bin 目录中。(需要把 GOPATH 下的 bin 目录添加到环境变量 Path 中)

1.png

完成上述操作后就可以使用 godoc 工具了,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 后,就可以看到本地文档浏览服务器提供的页面。

3.gif

godoc的使用

在终端查看

在终端,进入要查看的包的目录go doc显示当前包的文档

这里查看的是包名的文档,以及所有的函数名字跟变量类型名

example:    go doc    terminal show:    package test // import "test/testdoc"    这个是a.go的包名的描述    At 20191017 by Baiyu        ---a.go end---        这个是在doc.go 文件中的内容        在Go的源代码中        在Mac系统中        在类Unix系统中        在Windows系统中        ---doc.go end---        这个是在testgodoc.go文件的内容 package Name: test            describe:    程序的入口        ---testgodoc.go end---        这个是z.go 的包名描述        ---z.go end---        const Email ...    const Baiyu = "baiyu"    func H(h1 string, h2 string) (reValue string)    func Test(param1 string, inter int) (k string)    func Z()    type Computer struct{ ... }    type Person struct{ ... }        BUG: 这个注释会生成在文档最后后面,同时因为紧跟着fun Z,所以在上面的func列表里面也有显示    功能: 生成Z签名        BUG: 因为前面有BUG(who)这个关键字,所以这句注释就算没有紧跟关键字不会被隐藏掉        BUG: BUG(6):格式正确,所以这句注释就算没有紧跟关键字不会被隐藏掉,前面的BUG():、BUG6:、BUG:都是不正确的BUG(who)命名

登录后复制

go doc .查看pkg包下面的func函数的注释

example:    go doc test.Test    terminal show:     package test // import "test/testdoc"     func Test(param1 string, inter int) (k string)        功能: 测试函数           参  数:            param1  : 说明参数值            inter   : 运算的数字        返回值:            k       : 返回值

登录后复制

如果想查看完整的源码go doc -src .

example:     go doc -src test.Test     terminal show:    package test // import "test/testdoc"    // 功能: 测试函数    //  参  数:    //      param1  : 说明参数值    //      inter   : 运算的数字    //  返回值:    //      k       : 返回值    func Test(param1 string, inter int) (k string) {            fmt.Println("测试函数")            return param1    }

登录后复制

在浏览器上查看

使用命令godoc -http=:6060

然后在打开浏览器的,在url输入localhost:6060/pkg或者127.0.0.1:6060/pkg就可以查看到你本地的所有包的信息了

如果你想要找到你特定的包名的话localhost:6060/pkg//或者127.0.0.1:6060/pkg//

是你/src下包所在的路径

是包名

导出godoc文档为HTML

使用命令godoc -url “http://localhost:6060/pkg///” > .html

是你包所在的文件夹

是你的包名

导出来的是纯html文件,没有样式表,不过也有可能可以导出,但是我目前没有找到,如果有找到的朋友也可以交流一下

不过我也有把对应的样式文件给导出来了

下载地址https://github.com/BaiYu96/golandLearn/tree/master/learn_doc/stylefile

然后把html文件里面的css跟js指定的路径修改好就可以

【相关推荐:Go视频教程、编程教学】

以上就是golang怎么获取注释内容的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2415068.html

(0)
上一篇 2025年3月3日 00:50:47
下一篇 2025年3月1日 01:43:09

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • go语言多个变量怎么初始化

    多个变量初始化的方法:1、利用var关键字的形式来一次定义并初始化多个变量,语法“var(变量1 = 表达式1 变量2 = 表达式2 变量3 = 表达式3)”;2、使用冒号等于“:=”的形式来一次定义并初始化多个变量,语法“变量1, 变量2…

    2025年3月3日
    200
  • go语言中字符串怎么遍历

    字符串遍历方法:1、使用“for range”语句遍历,语法“for key, value := range str {…}”;2、使用strings包的Map()函数来遍历,语法“trings.Map(func(rune), …

    2025年3月3日
    200
  • go语言怎么重复字符串

    在go语言中,可以使用Strings包里的Repeat()函数来重复字符串;该函数可以重复指定次数的字符串 本教程操作环境:windows7系统、GO 1.18版本、Dell G3电脑。 在go语言中,可以使用Strings包里的Repea…

    2025年3月3日
    200
  • goland是什么

    Goland是由JetBrains公司专为Go开发的跨平台的商业IDE,旨在为Go开发者提供的一个符合人体工程学的IDE。Goland整合了IntelliJ 平台(一个用于 java 语言开发的集成环境,也可用于其他开发语言),提供了针对G…

    2025年3月3日 编程技术
    200
  • golang包的特性是什么

    特性:1、包名一般是小写,用一个简短且有意义的名称;2、包名一般要和所在的目录同名,也可不同名,包名中不能包含“-”等特殊符号;3、包一般使用域名作为目录名称,这样能保证包名的唯一性;4、包名为main的包为应用程序的入口包,编译源码时如果…

    2025年3月3日
    200
  • golang切片的长度与容量是什么

    在golang中,切片长度就是切片中元素的数量;切片容量是从创建切片的索引开始的底层数组中元素的数量,即从切片的第一个元素开始数,到其底层数组元素末尾的个数。切片的长度与容量是可以计算的,内置方法len()可获取长度,cap()可获取容量;…

    2025年3月3日
    200
  • go语言中数组与切片有什么区别

    数组与切片的区别:1、切片是指针类型,数组是值类型;2、数组的赋值形式为值传递,切片的赋值形式为引用传递;3、数组的长度是固定的,而切片长度可以任意调整(切片是动态的数组);4、数组的长度是固定的,而切片长度可以任意调整(切片是动态的数组)…

    2025年3月3日
    200
  • go语言怎么比较字符串

    比较方法:1、直接使用“==”运算符比较,语法“str1 == str2”,该方法区分大小写。2、利用strings包的Compare()函数比较,语法“strings.Compare(a,b)”;返回值为int类型,0表示两数相等,1表示…

    2025年3月3日
    200
  • golang怎么添加list元素

    添加方法:1、用InsertBefore()函数在列表指定元素(mark点)前插入元素,语法“InsertBefore(v,mark)”;2、用InsertAfter()函数在列表指定元素(mark点)后插入元素,语法“InsertAfte…

    2025年3月3日 编程技术
    200
  • go语言怎么获取list长度

    在go语言中,可以使用列表内置的Len()函数来获取list长度,语法“列表list.Len()”,返回值为指定list的长度。Len()函数可用于计算数组(包括数组指针)、切片(slice)、map、channel、字符串等数据类型的长度…

    2025年3月3日
    100

发表回复

登录后才能评论