go-callvis是相对 以图片的形式展现了go程序的调用关系,这个工具在看复杂项目时尤为有用。git
亲测,借助它看祖传golang代码,头痛好多了。
go get -u github.com/TrueFurby/go-callvis # or git clone https://github.com/TrueFurby/go-callvis.git cd go-callvis && make install
运行依赖github
项目地址:https://github.com/TrueFurby/go-callvisgolang
命令特别简单,只须要简单的输入:docker
go-callvis [OPTIONS] <main package>
这里 main package 是包含代码的main函数所在的包,好比项目 https://github.com/gusibi/one...小程序
目录结构为:设计模式
. ├── 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:7878并发
图片格式为 svg,也能够添加 -format=png,指定以png形式展现推荐使用svg,svg格式的内容是可交互的,好比这里想查看gin包的内容就能够点击 对应的模块来看详情。框架
结果若是所示,图像展现的结果就是这个包全部的调用关系,按包的调用层级由左向右排列。第二列上边是 gin 框架的代码,若是看代码时不想看这部分,可使用 ignore 参数排除掉。svg
命令为:
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
结果如图:
详细命令能够参考:https://github.com/TrueFurby/...
使用go-callvis ,直观的展现代码的调用关系,对于大项目的源码尤为有用,好比下图是gin stagic 包的调用关系:
经过图能够直观的看到,
go-callvis 也能够用来评估系统设计是否合理,代码是否清晰,下图是docker 的调用图:
原图地址: http://media.gusibi.mobi/8vZ7...
能够看到,代码结构很是清晰,调用链也比较简单,项目成功果真每一环都作的很是完美。
如下是shopee内推广告,「深圳、新加坡、上海」的职位都有,感兴趣的能够留言或者识别二维码直接投递。
最后,感谢女友支持和包容,比❤️
也能够在公号输入如下关键字获取历史文章:公号&小程序
| 设计模式
| 并发&协程
[1]
go-callvis: https://github.com/TrueFurby/...[2]
Go: https://golang.org/dl/[3]
Graphviz:http://www.graphviz.org/downl...: http://www.graphviz.org/downl...[4]
项目地址:https://github.com/TrueFurby/...: https://github.com/TrueFurby/...