2024年Go最新聊一聊 golang 的测试与性能调优_golang 性能测试,2024年最新42岁程序员面试

img
img
img

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

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

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

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
10ms 5.88% 100% 10ms 5.88% runtime.stdcall3
0 0% 100% 10ms 5.88% runtime.(*pageAlloc).scavenge
0 0% 100% 10ms 5.88% runtime.(*pageAlloc).scavengeOne
0 0% 100% 10ms 5.88% runtime.(*pageAlloc).scavengeRangeLocked
0 0% 100% 10ms 5.88% runtime.bgscavenge.func2
0 0% 100% 10ms 5.88% runtime.sysUnused
0 0% 100% 10ms 5.88% runtime.systemstack
0 0% 100% 160ms 94.12% testing.(*B).launch
0 0% 100% 160ms 94.12% testing.(*B).runN


**喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一 键三连哦!**



![img](https://img-blog.csdnimg.cn/img_convert/9cb19338e5249c0ac6b8df2138a477bd.png)
![img](https://img-blog.csdnimg.cn/img_convert/1bfaaf45232b4bc17109a85091e13512.png)

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

**[需要这份系统化的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618658159)**


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

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


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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值