0

0

如何在 Go 中程序化获取并保存基准测试结果

聖光之護

聖光之護

发布时间:2026-01-12 13:02:24

|

542人浏览过

|

来源于php中文网

原创

如何在 Go 中程序化获取并保存基准测试结果

本文介绍如何使用 go 标准库的 `testing.benchmark` 函数主动调用基准测试,获取 `testing.benchmarkresult` 实例,并将其结构化输出到文件,从而实现对性能数据的自动化采集与持久化。

在 Go 中,默认的 go test -bench 命令仅将基准测试结果打印到标准输出,无法直接编程访问或导出。但 Go 的 testing 包提供了 testing.Benchmark(func(*testing.B)) 函数——它允许你在普通 main 程序中显式执行一个基准函数,并返回一个完整的 testing.BenchmarkResult 结构体,包含所有关键性能指标:N(执行次数)、T(总耗时,纳秒)、Bytes(每操作字节数)、MemAllocs(内存分配次数)和 MemBytes(总分配字节数)等。

以下是一个完整可运行的示例:

package main

import (
    "encoding/json"
    "fmt"
    "os"
    "testing"
    "time"
)

func Add(a, b int) int {
    time.Sleep(10 * time.Microsecond) // 模拟轻微开销,确保可测性
    return a + b
}

func BenchAdd(b *testing.B) {
    for i := 0; i < b.N; i++ {
        _ = Add(1, 2)
    }
}

func main() {
    // 主动执行基准测试,获取结构化结果
    result := testing.Benchmark(BenchAdd)

    // 打印人类可读摘要(与 go test -bench 输出格式一致)
    fmt.Printf("%-12s %8d %8.0f ns/op\n",
        "BenchAdd", result.N, float64(result.T)/float64(result.N))

    // 输出完整 BenchmarkResult(调试用)
    fmt.Printf("Raw result: %+v\n", result)

    // ✅ 序列化为 JSON 并写入文件(推荐用于后续分析)
    data, err := json.MarshalIndent(result, "", "  ")
    if err != nil {
        panic(err)
    }

    if err := os.WriteFile("benchmark_result.json", data, 0644); err != nil {
        panic(err)
    }
    fmt.Println("✅ Benchmark result saved to benchmark_result.json")
}

运行该程序(go run main.go)将输出类似:

BenchAdd       120000    10000 ns/op
Raw result: {N:120000 T:1200000000 Bytes:0 MemAllocs:0 MemBytes:0 Extra:map[]}
✅ Benchmark result saved to benchmark_result.json

生成的 benchmark_result.json 内容如下(结构清晰、易于 CI/CD 解析):

Google AI Studio
Google AI Studio

Google 推出的基于浏览器的集成开发环境

下载
{
  "N": 120000,
  "T": 1200000000,
  "Bytes": 0,
  "MemAllocs": 0,
  "MemBytes": 0,
  "Extra": {}
}

⚠️ 注意事项:

  • testing.Benchmark 只能在非测试包中调用(即 package main),且不能与 go test 混用;它绕过了测试框架的自动发现机制,适用于需要精确控制执行环境或集成进构建流水线的场景。
  • time.Sleep 仅用于演示;真实基准应避免非必要阻塞,确保测量的是目标逻辑本身。
  • 若需多组对比(如不同参数、版本),可循环调用 testing.Benchmark 并聚合多个 BenchmarkResult。
  • Extra 字段支持通过 b.ReportMetric(value, unit) 注册自定义指标(如 QPS、错误率),增强可观测性。

通过这种方式,你不再依赖终端输出,而是获得可编程、可序列化、可版本化管理的性能数据,为持续性能监控(CPM)打下坚实基础。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

408

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

187

2025.07.04

PHP 命令行脚本与自动化任务开发
PHP 命令行脚本与自动化任务开发

本专题系统讲解 PHP 在命令行环境(CLI)下的开发与应用,内容涵盖 PHP CLI 基础、参数解析、文件与目录操作、日志输出、异常处理,以及与 Linux 定时任务(Cron)的结合使用。通过实战示例,帮助开发者掌握使用 PHP 构建 自动化脚本、批处理工具与后台任务程序 的能力。

26

2025.12.13

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

78

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

46

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号