golang 性能调优_benchmark测反应

golang 性能调优_benchmark测反应Golang性能基准测试可以帮助开发人员比较不同的实现方式对性能的影响,以便优化程序,本文就来讲解一下如何使用Golang的性能基准测试功能。

Golang性能基准测试可以帮助开发人员比较不同的实现方式对性能的影响,以便优化程序,本文就来讲解一下如何使用Golang的性能基准测试功能。

Golang 性能基准测试

Golang 中的性能基准测试是使用标准库 testing 来实现的,编写性能测试代码是很容易的:

  1. 创建性能测试文件:在 Go 项目的源代码目录下创建一个新的文件(和被测代码文件在同一个包),以 _test.go 为后缀名。例如,要测试net包中 dial.go 中的方法,在 net 包中创建一个名字为 dial_test.go 文件,和单元测试文件是一样的。
  2. 导入 testing 包:在测试文件中导入testing包,以使用相关的的函数和工具。
  3. 编写测试函数:在测试文件中,编写一个以 Benchmark 为前缀的函数,后面跟上一个或多个字符或字符组合来标识测试用例的名称(一般使用被测的函数名称),参数必须是 b *testing.B。
  4. 编写测试代码:b.N是基准测试框架提供的,表示循环的次数,因为需要反复调用测试代码来评估性能。b.N 的值会以1, 2, 5, 10, 20, 50, …这样的规律递增下去直到运行时间大于1秒钟,由于程序判断运行时间稳定才会停止运行,所以千万不要在loop循环里面使用一个变化的值作为函数的参数。

以 json 格式校验工具
https://github.com/luduoxin/json-validator-go 为例,validator包中的 scanner.go 文件中的关键函数 Valid 用于校验给定字符串是否 json 格式,对应的性能测试文件为 scanner_test.go,里面的测试函数为 BenchmarkValid,代码如下:

package validator

import "testing"

func BenchmarkValid(b *testing.B) {
	str := `{"foo":"bar"}`
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		Valid([]byte(str))
	}

运行性能测试用例

性能测试命令为 go test [参数],比如 go test -bench=. ,具体的命令参数及含义如下:

-bench regexp 性能测试,运行指定的测试函

-bench . 运行所有的benchmark函数测试,指定名称则只执行具体测试方法而不是全部

-benchmem 性能测试的时候显示测试函数的内存分配的统计信息

-count n 运行测试和性能多少此,默认一次

-run regexp 只运行特定的测试函数

-timeout t 测试时间如果超过 t 则panic,默认10分钟

-v 显示测试的详细信息

启动命令行,切换到 json-validator-go 项目的 validator 文件夹下,运行全部性能测试用例:

$ go test -bench=.
goos: darwin
goarch: amd64
pkg: github.com/luduoxin/json-validator-go/validator
cpu: Intel(R) Core(TM) i5-8259U CPU @ 2.30GHz
BenchmarkValid-8        13562608                86.55 ns/op
PASS
ok      github.com/luduoxin/json-validator-go/validator 1.420s

上面输出的报告的倒数第三行信息的内容含义如下:

BenchmarkValid 是性能测试函数名称,-8 表示 GOMAXPROCS 的值为8,13562608 表示一共执行了13562608次,即b.N的值,86.55 ns/op 表示平均每次操作花费了 86.55 纳秒。

在一个测试方法里面也可以跑多个用例,使用更多的类型的数据分别看下对应的性能,代码如下:

package validator

import "testing"

func BenchmarkValid(b *testing.B) {
	var validTests = []struct {
		data string
		ok   bool
	}{
		{`foo`, false},
		{`}{`, false},
		{`{]`, false},
		{`{}`, true},
		{`[{}]`, true},
		{`{"foo":"bar"}`, true},
		{`{"foo":"bar","bar":{"baz":["qux"]}}`, true},
	}

	for _, v := range validTests {
		b.Run("", func(b *testing.B) {
			for i := 0; i < b.N; i++ {
				Valid([]byte(v.data))
			}
		})
	}
}

运行看下效果:

$ go test -bench=. 
goos: darwin
goarch: amd64
pkg: github.com/luduoxin/json-validator-go/validator
cpu: Intel(R) Core(TM) i5-8259U CPU @ 2.30GHz
BenchmarkValid/#00-8             4746290               249.8 ns/op
BenchmarkValid/#01-8             4841005               245.5 ns/op
BenchmarkValid/#02-8             4610671               257.0 ns/op
BenchmarkValid/#03-8            26957421                42.63 ns/op
BenchmarkValid/#04-8            29747263                41.88 ns/op
BenchmarkValid/#05-8            20895832                56.31 ns/op
BenchmarkValid/#06-8            14058906                83.17 ns/op
BenchmarkValid/#07-8             5518412               212.9 ns/op
PASS
ok      github.com/luduoxin/json-validator-go/validator 10.891s

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/11779.html

(0)

相关推荐

  • 【C 语言】数组作为参数退化为指针问题

    【C 语言】数组作为参数退化为指针问题文章目录 一、问题描述 二、从编译器角度分析该问题 三、数组作为参数的推荐方案 一、问题描述 将 数组 作为 函数参数 , 传递时会 退化为指针 ; 数组的首地址 , 变为指针地址 , 函数中无法判定

    2023-11-13
    141
  • 如何使用 React 制作一个贪吃蛇游戏?

    如何使用 React 制作一个贪吃蛇游戏?在 React 中创建贪吃蛇游戏 Snake Game 使用 ReactJS 项目实现功能组件并相应地管理状态。开发的游戏允许用户使用箭头键控制蛇或触摸屏幕上显示的按钮来收集食物并增长长度。游戏的目标

    2023-11-15
    135
  • Mysql-connector「建议收藏」

    Mysql-connector「建议收藏」Mysql-connector-java驱动版本问题 由于我的数据库版本是5.7.28 ,在使用java连接mysql时经常出现版本问题。 com.mysql.jdbc.Driver 是 mysql-

    2023-04-17
    173
  • 使用PyCharm编写Python代码

    使用PyCharm编写Python代码Python作为一种易于学习且功能强大的编程语言,已经被广泛应用于数据分析、科学计算和Web应用程序等领域。而在编写Python代码时,一个好的集成开发环境(IDE)是至关重要的。PyCharm是由JetBrains开发的一款强大的Python IDE,它拥有丰富的功能和智能的提示,可以提高编码效率,减少开发错误。

    2024-06-06
    62
  • Python中的Finally语句

    Python中的Finally语句无论在什么编程语言中,错误处理都是一项必要的任务。在Python中,除了用try和except语句来处理代码块中的异常外,还有一个重要的语句:finally语句。finally语句表示不管try中的代码是否抛出异常,finally中的代码都会被执行。这使它比其他语句更加的强大。

    2024-05-28
    53
  • Python中环境变量的重要性

    Python中环境变量的重要性作为一名Python工程师,对于Python中环境变量的重要性,不能不重视。环境变量是操作系统用于存储某些信息的位置,在程序运行的时候起到了非常大的作用。因此,在编写Python程序时,我们需要了解环境变量的具体信息,以充分利用这一特性。

    2024-08-18
    31
  • hbase协处理器使用_hdfs和hbase的关系

    hbase协处理器使用_hdfs和hbase的关系本文主要给大家罗列了HBase协处理器加载的三种方式:Shell加载(动态)、Api加载(动态)、配置文件加载(静态)。其中静态加载方式需要重启HBase。 我们假设我们已经有一个现成的需要加载的协处

    2023-02-18
    150
  • 大数据分析平台 低代码开发 机智云AIoT云平台[通俗易懂]

    大数据分析平台 低代码开发 机智云AIoT云平台[通俗易懂]数字化浪潮已席卷各行各业,数字经济已成为支撑经济发展的重要动力。在以大数据为核心资源的数字经济时代,大部分行业都试图在这场浪潮中把握先机实现转型

    2022-12-14
    203

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注