go语言基准测试Benchmark 最佳实践-冒泡排序和快速排序算法基准测试时间复杂度对比

embedded/2024/10/19 12:15:00/

在go语言中Benchmark基准测试( 在后缀为_test.go的文件中,函数原型为 func BenchmarkXxx(b *testing.B) {}的函数 )可以用来帮助我们发现代码的性能和瓶颈, 其最佳实践 应该是我们最常用的 冒泡排序快速排序的测试了,废话不说,直接上代码:

冒泡排序和快速算法>排序算法代码 sort_algorithm.go

package sortingimport "math/rand"// 冒泡算法>排序算法
func BubbleSort(arr []int) {n := len(arr)for i := 0; i < n-1; i++ {for j := 0; j < n-i-1; j++ {if arr[j] > arr[j+1] {arr[j], arr[j+1] = arr[j+1], arr[j]}}}
}// 快速算法>排序算法入口
func QuickSort(arr []int) {quickSort(arr, 0, len(arr)-1)
}// 快排算法
func quickSort(arr []int, low, high int) {if low < high {pivot := partition(arr, low, high)quickSort(arr, low, pivot-1)quickSort(arr, pivot+1, high)}
}// 快排拆分逻辑
func partition(arr []int, low, high int) int {pivot := arr[high]i := low - 1for j := low; j < high; j++ {if arr[j] < pivot {i++arr[i], arr[j] = arr[j], arr[i]}}arr[i+1], arr[high] = arr[high], arr[i+1]return i + 1
}// 生成指定长度的随机数字切片
func makeRandomNumberSlice(n int) []int {numbers := make([]int, n)for i := range numbers {numbers[i] = rand.Intn(n)}return numbers
}const LENGTH = 10_000

冒泡排序和快速算法>排序算法代码基准测试用例 sort_algorithm_test.go

注意:b.N 基准函数必须运行目标代码b.N次。在基准测试执行期间, b.N 会被动态调整来确保基准测试函数能够持续足够长的时间,从而确保时间的可靠性。

package sortingimport "testing"// 基准测试运行命令: go test -bench=.   这里的.表示运行当前所有的基准测试, 也可以指定函数名
// benchmark基准测试用例func BenchmarkBubbleSort(b *testing.B) {for i := 0; i < b.N; i++ {b.StopTimer() // 停止计时numbers := makeRandomNumberSlice(LENGTH)b.StartTimer() // 开始计时BubbleSort(numbers)}
}func BenchmarkQuickSort(b *testing.B) {for i := 0; i < b.N; i++ {b.StopTimer() // 停止计时numbers := makeRandomNumberSlice(LENGTH)b.StartTimer() // 开始计时QuickSort(numbers)}
}

运行结果

上面的结果中, 1-4行表示的是你当前测试用的机器的信息

在第5行的测试结果中第一列的 BenchmarkBubbleSort-16 这里的16表示有16个CPU来执行测试;

第二列的数字32表示循环了32次 这个数字越大越好

第三列的 35757363 ns/op 表示 每次操作的用时 35757363 纳秒 这个数字越小越好

通过上面的基准测试结果,我们可以非常直观的得出结论, 快速算法>排序算法的表现最佳 ,他的时间复杂度为 O(n log n), 而冒泡排序表现较差,时间复杂度为 O(n^2)

参考

testing package - testing - Go Packages

https://dev.tekin.cn/


http://www.ppmy.cn/embedded/43486.html

相关文章

【HarmonyOS】View点击穿透,层叠View点击事件控制

【HarmonyOS】View点击穿透&#xff0c;层叠View点击事件控制 问题背景&#xff1a; 在HarmonyOS中&#xff0c;经常会有层叠的View的布局&#xff0c;当碰到需要穿透的布局需求。就需要能控制View对点击事件的处理。 方案一&#xff0c;使用touchable&#xff1a; 目前虽然函…

用大模型搭建一个自己的新闻小助手

背景 信息快速增长的时代&#xff0c;及时获取到有价值的资讯是一件很必要的事情。已经有各类新闻app和获取信息的渠道了&#xff0c;为什么还需要在构建一个小助手来获取新闻资讯呢&#xff1f;其实原因很简单各类新闻app服务的是具体一类人群&#xff0c;个人和人群还是有偏…

某勾求职网逆向分析

搜索目标: aHR0cHM6Ly93d3cubGFnb3UuY29tL3duL2pvYnM/cG49MSZweD1kZWZhdWx0JmZyb21TZWFyY2g9dHJ1ZSZrZD0lRTYlOTUlQjAlRTYlOEQlQUUlRTUlODglODYlRTYlOUUlOTA= 抓包分析 请求和返回都是加密的 请求头部也有未知参数 跟栈分析 请求和返回是一个AES加密,加密的KEY是session s…

三前奏:获取/ 读取/ 评估数据【数据分析】

各位大佬好 &#xff0c;这里是阿川的博客 &#xff0c; 祝您变得更强 个人主页&#xff1a;在线OJ的阿川 大佬的支持和鼓励&#xff0c;将是我成长路上最大的动力 阿川水平有限&#xff0c;如有错误&#xff0c;欢迎大佬指正 前面的博客 数据分析—技术栈和开发环境搭建 …

列表元素添加的艺术:从单一到批量

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、引言 二、向列表中添加单一元素 1. append方法 2. insert方法 三、向列表中添加批量…

React hooks - useRef

useRef 用法特点注意事项 用法 useRef 函数返回一个可变的 ref 对象&#xff0c;该对象只有一个 current 属性。可以在调用 useRef 函数时为其指定初始值。并且这个返回的 ref 对象在组件的整个生命周期内保持不变。 // 1. 导入 useRef import { useRef } from react // 2. 调…

ubuntu 配置用户登录失败尝试次数限制

前言&#xff1a; 通过修改pam配置来达到限制密码尝试次数&#xff01; 1&#xff1a;修改 /etc/pam.d/login 配置&#xff08;这里只是终端登录配置&#xff0c;如果还需要配置SSH远程登录限制&#xff0c;只配置下面的 /etc/pam.d/pam.d/common-auth 即可&#xff09; vim…

Java多线程(02)

一、如何终止线程 终止线程就是要让 run 方法尽快执行结束 1. 手动创建标志位 可以通过在代码中手动创建标志位的方式&#xff0c;来作为 run 方法的执行结束条件&#xff1b; public static void main(String[] args) throws InterruptedException {boolean flag true;Thr…