2024年最全聊一聊 golang 的测试与性能调优_golang 性能测试,2024年最新Activity的6大难点你会几个

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

“testing”
)

func TestAdd(t *testing.T) {

testCases := []struct{
a int
b int
c int
}{
{3,2,1 },
{10,5,5},
{ 1000000,1,999999},
}

for _, testCase := range testCases{
if result:=Add(testCase.b,testCase.c); result!=testCase.a{
t.Errorf("Expected get %d, but got: %d ", testCase.a, result)
}
}
}


当一个函数的参数为 testing.T时,同样标志着这是一个单例测试函数。


随后我们可以直接在IDE 中点击函数旁边的小三角进行运行, 也可以在命令行中输入



go test -run TestAdd


这条命令会 指定测试 哪一个函数,如果想要测试当前包下的所有测试函数,也可以用下面这条命令



go test .


### 写一个压力测试函数


说完单例测试,该说压力测试了。在刚刚的 TestAdd 下面写一个 BenchmarkAdd 函数。


同样的压力测试函数也是有命名规则的,以Benchmark打头,接上被测试函数的名字, 并且参数wei tesing.B 。同样的,若果你在IDE中,写完 Bench 也应该会有代码补全提示。



func BenchmarkAdd(b *testing.B) {

b.ResetTimer()
for i := 0; i<b.N;i++ {
if result:=Add(1,9999999); result !=10000000 {
b.Errorf("Expected get %d, but got: %d ", 10000000 , result)
}
}
}


压力测试同样也可以在IDE中函数旁边的小三角运行,但更多的使用的是命令行。可以使用下面两条命令的任意一种。区别只在于第一条命令指定了运行哪一个函数,第二条命令运行所有压测函数。



go test -bench BenchmarkAdd -cpuprofile cpu.out
go test -bench . -cpuprofile cpu.out


go test -bench 函数名 指明了测试哪一个函数。 后面的 -cpuprofile cpu.out 则说明了监控CPU运行时的状态并且输出到了 一个 cpu.out 文件。


### 安装 graphviz


想要看这个 cpu.out 文件需要用到一个 graphviz的插件,大家可以去官网直接下载对应的版本即可。 下载完成后将安装目录下的 bin 目录加到环境变量中, 重启即可。如果不重启,在IDE中可能仍然无法使用,这是个大坑。 重启完成后在命令行输入下面这条命令如果有输出graphviz信息,说明安装成功



dot -version


回到刚刚的压力测试,在输出的 cpu.out 路径下输入下面这行命令:



go tool pprof cpu.out


然后会进入到 pprof 命令行, 我们可以输入 web , 那么则会弹出浏览器得到一张图,详细展示了 运行过程中每一个函数的消耗时间。


![在这里插入图片描述](https://img-blog.csdnimg.cn/8a85efda1bd94f128ec130a9cd681c02.png)


你可能会好奇这张图怎么看。细节我也不太会,**但是你只要看到框框越大,颜色越红,就代表这个函数消耗时间越多。**


你也可以在 pprof 的命令行中输入 top 获得排名靠前的资源消耗函数。结果大概张这样



Showing nodes accounting for 170ms, 100% of 170ms total
flat flat% sum% cum cum%
160ms 94.12% 94.12% 160ms 94.12% GoBasic/test.BenchmarkAdd

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

/bbs.csdn.net/topics/618658159)**

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 16
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值