Go语言之性能测试相关(基准测试)

ZhDavis · · 1823 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

来自公众号:灰子学技术

 原文链接:https://mp.weixin.qq.com/s/CmiPafXfvzJjM6UxaFCaCQ

在Go语言中,提供了测试函数性能(CPU和Memory)的测试方法,基准测试。

基准测试主要用来测试CPU和内存的效率问题,来评估被测代码的性能。测试人员可以根据这些性能指标的反馈,来优化我们的代码,进而提高性能问题。

本篇文章主要来介绍,基准测试的使用方法和性能指标的分析。

1. 使用规则如下所示:

1.基准测试的代码文件必须以_test.go结尾。

2.基准测试的函数必须以Benchmark开头。

3.基准测试函数必须接受一个指向testing.B类型的指针作为唯一参数。

4.在测试执行之前,需要调用b.ResetTimer(重置计时器)来重置时间,以便过滤掉测试之前代码所消耗的时间。

5.测试代码需要写在for循环中,并且循环中的最大之是b.N。

2.用例介绍:

文件结构为: benchmark.go,  benchmark_test.go,测试用例的写法,参看右边的测试代码。

3.运行基准测试:

$ go test -bench=. -benchtime=5s -benchmem -run=none

参数介绍:

-bench=. :表示的是运行所有的基准测试,. 表示全部。

-benchtime=5s:表示的是运行时间为5s,默认的时间是1s。

-benchmem:表示显示memory的指标。

-run=none:表示过滤掉单元测试,不去跑UT的cases。

输出的结果内容分析:

goos: darwin:表示的是操作系统是darwin。

goarch: amd64:表示目标平台的体系架构是amd64。

BenchmarkHandleWithType-4:BenchmarkHandleWithType表示运行的函数名称; 4表示的是,运行时对应的GOMAXPROCS的值。

10000000000:表示的是b.N的在5s内的值。

0.28 ns/op:表示执行一次这个函数,消耗的时间是0.28ns。

0 B/op:表示每次执行操作,分配0B的内存。

0 allocs/op:表示执行一次这个函数,分配内存的次数为1次。

参考文章:
Golang在Mac、Linux、Windows下如何交叉编译:https://laucyun.com/5d140bb00295137f0caa0ade248390fb.html

Go学习笔记(三) | 怎么写Go基准测试(性能测试):https://razeencheng.com/post/go-how-to-write-benchmark.html

Go语言实战笔记(二十二)| Go 基准测试:https://www.flysnow.org/2017/05/21/go-in-action-go-benchmark-test.html

1. Go 性能调优之 —— 基准测试:https://segmentfault.com/a/1190000016354758

 

《一个C++程序员学习Go语言的笔记》正在继续,首发在公众号 灰子学技术,欢迎大家关注,点评,如果觉得有帮助,顺手分享到朋友圈吧,谢谢~

 


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1823 次点击  
加入收藏 微博
被以下专栏收入,发现更多相似内容
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传