go-callvis是相对 以图片的形式展现了go程序的调用关系,这个工具在看复杂项目时尤为有用。git
亲测,借助它看祖传golang代码,头痛好多了。github
go get -u github.com/TrueFurby/go-callvis
# or
git clone https://github.com/TrueFurby/go-callvis.git
cd go-callvis && make install
复制代码
运行依赖golang
项目地址:https://github.com/TrueFurby/go-callvisdocker
命令特别简单,只须要简单的输入:小程序
go-callvis [OPTIONS] <main package>
复制代码
这里 main package 是包含代码的main函数所在的包,好比项目 github.com/gusibi/onep…设计模式
目录结构为:浏览器
.
├── README.md
└── src
├── dbs
├── go.mod
├── go.sum
├── idg
│ ├── area_code.go
│ ├── idg.go
│ ├── idg_test.go
│ ├── index.go
│ ├── index_test.go
│ ├── sort.go
│ ├── sort_test.go
│ ├── wr.go
│ └── wr_test.go
├── main.go
└── sorteDB
复制代码
其中src目录是一个go package,运行go-callvis 时就须要先cd src/,而后再执行命令:并发
go-callvis -group pkg,type md52id
复制代码
md52id 是package name,已在go.mod中声明,pakage name是一个必需要带的参数。框架
运行命令,默认会打开浏览器加载地址http://localhost:7878svg
图片格式为 svg,也能够添加 -format=png,指定以png形式展现
推荐使用svg,svg格式的内容是可交互的,好比这里想查看gin包的内容就能够点击 对应的模块来看详情。
结果若是所示,图像展现的结果就是这个包全部的调用关系,按包的调用层级由左向右排列。第二列上边是 gin 框架的代码,若是看代码时不想看这部分,可使用 ignore 参数排除掉。
命令为:
go-callvis -group pkg,type -ignore github.com/gin-gonic/gin md52id
复制代码
这里 gin 包的名字是 github.com/gin-gonic/gin而不是 gin
若是要再排出idg 包,能够直接加在gin 包后边,用,(英文逗号)隔开。
使用limit 命令能够获得相同的结果
go-callvis -group pkg,type -limit md52id md52id
获得的结果为:
若是想看idg包内部的调用关系,可使用 focus 命令,指定idg 包,命令以下:
go-callvis -focus=md52id/idg -group pkg,type -limit md52id md52id
复制代码
结果如图:
详细命令能够参考:github.com/TrueFurby/g…
使用go-callvis ,直观的展现代码的调用关系,对于大项目的源码尤为有用,好比下图是gin stagic 包的调用关系:
经过图能够直观的看到,
go-callvis 也能够用来评估系统设计是否合理,代码是否清晰,下图是docker 的调用图:
能够看到,代码结构很是清晰,调用链也比较简单,项目成功果真每一环都作的很是完美。
如下是shopee内推广告,「深圳、新加坡、上海」的职位都有,感兴趣的能够留言或者识别二维码直接投递。
最后,感谢女友支持和包容,比❤️
也能够在公号输入如下关键字获取历史文章:公号&小程序
| 设计模式
| 并发&协程
[1]
go-callvis: github.com/TrueFurby/g…
[2]
Go: golang.org/dl/
[3]
Graphviz:www.graphviz.org/download/: www.graphviz.org/download/