golang-使用godoc 工具编写代码注释

导语:良好的注释是代码可维护的基础之一,作为golang 开发者,更应该意识到go 官方已经提供了godoc 工具,只要我们代码的注释是按照规范来,最后也能生成比较直观的“文档”,因此平时开发 的时候也应该重视注释的细节。

一、本地安装godoc 工具

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

然后本地启动:
godoc -http=:6060

然后就可以查看go 原生库的文档了,只要代码本身的注释是比较规范的,生成的godoc 也会比较好看.

二、查看本地项目的godoc

如果本地的项目没有在GOROOT 路径下,除非设置软链接,才能通过godoc 来看否则只能通过 go doc 指令查看:

cd 到项目根目录,然后直接执行 go doc 即可。

go doc util

效果如下:
godoc 直接在终端展示出来了

三、简述godoc 规范

官方示例:sync godoc

1、package 注释

首先,整个package ,但是不需要每个方法都写上一样的定义,只要在其中一个文件中写上就可以了。sync包的注释 就在mutex 中

2、结构体注释

在这里插入图片描述
如上图,直接在 struct 前面定义即可。

注意:struct 的对象如果没有加上注释,在godoc 中就会显示:contains filtered or unexported fields

3、方法注释

注释位置同上
一般对外的方法是一定要添加注释的

4、常量注释

如果要让const 显示出注释,就应该所有的常量都添加注释
如果只添加了部分常量,有可能显示会有问题

5、doc.go

一般用在项目的根目录中。

前面说到添加 package 的注释,可以在package 下的任意一个文件中添加,但是如果本身根目录的文件就很多了,有的时候确实很难定到底应该放到哪个文件中,而且后期不好找。
doc.go 一般就是作为 package 的注释用的,也经常出现在开源项目的根目录中。

举个例子:grpc
在这里插入图片描述
在这里插入图片描述

四、实战:给自己的项目添加godoc

项目地址
生成的godoc 地址(util包)
在这里插入图片描述

开源项目的godoc 直接通过 godoc.org/项目完整路径 访问即可。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
golang-lru 是一个 Golang 语言实现的 LRU 缓存库,它提供了一个简单易用的 API 用于创建和使用 LRU 缓存。 下面是一个简单的使用示例: ```go package main import ( "fmt" "github.com/hashicorp/golang-lru" ) func main() { // 创建一个 LRU 缓存,容量为 2 cache, _ := lru.New(2) // 添加两个元素到缓存中 cache.Add("key1", "value1") cache.Add("key2", "value2") // 从缓存中获取一个元素 if v, ok := cache.Get("key1"); ok { fmt.Println(v.(string)) } // 添加一个新元素到缓存中,此时缓存容量已满,会自动淘汰最久未使用的元素 "key2" cache.Add("key3", "value3") // 遍历缓存中的所有元素 for _, k := range cache.Keys() { if v, ok := cache.Get(k); ok { fmt.Println(k, v.(string)) } } } ``` 运行上述代码,将会输出: ``` value1 key1 value1 key3 value3 ``` 在这个示例中,我们首先使用 `lru.New()` 函数创建了一个容量为 2 的 LRU 缓存。然后我们添加了两个元素到缓存中,并从缓存中获取了一个元素。接着我们添加了一个新元素,此时缓存已满,会自动淘汰最久未使用的元素 "key2"。最后我们遍历了缓存中的所有元素,输出了它们的键和值。 除了 `Add()` 和 `Get()` 方法外,golang-lru 还提供了 `Remove()` 和 `Contains()` 方法来删除和判断缓存中是否存在某个元素,以及 `Len()` 和 `Clear()` 方法来获取缓存中元素的数量和清空缓存。 golang-lru 还支持并发安全,你可以通过 `NewWithOptions()` 函数创建一个并发安全的 LRU 缓存,具体用法请参考官方文档:https://pkg.go.dev/github.com/hashicorp/golang-lru。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值