loopvar 改动不同版本的影响-大循环的执行时间

2024-04-03 03:36

本文主要是介绍loopvar 改动不同版本的影响-大循环的执行时间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

示例代码

package mainimport ("fmt""runtime""time"
)type Large [1 << 12]bytefunc readOnly(x *Large, k int) {}
func foo() {for a, i := (Large{}), 0; i < len(a); i++ {readOnly(&a, i)}
}
func bench() time.Duration {start := time.Now()foo()return time.Since(start)
}
func main() {fmt.Println("golang version:", runtime.Version())fmt.Println("elapsed time:", bench())
}

代码说明

代码定义foo方法,循环了一个长度有4k的slice,readonly是一个空方法,只是为了演示用的,bench为计算循环执行时长的方法

golang 1.21的运行结果

go run demo/large_for.go
golang version: go1.21.5
elapsed time: 1.202µs

可以看到在golang 1.21.5的版本中执行的时间是1.2us,在1.22中执行时间是会变长还是变短呢?

golang 1.22的运行结果

go run demo/large_for.go
golang version: go1.22.1
elapsed time: 754.581µs

是不是很吃惊,1.22居然用了784us,比1.21的执行时间要长了很多倍。

下面我们定义一个长度为1000的struct,然后遍历这个struct。看下执行的时间.

package mainimport ("fmt""runtime""time"
)type Person struct {Name   stringAge    uint8Sex    stringHeight uint8
}var Large [1000]Personfunc readOnly(x *Person, k int) {}func foo() {for i, l := range Large {readOnly(&l, i)}
}
func bench() time.Duration {start := time.Now()foo()return time.Since(start)
}
func main() {fmt.Println("golang version:", runtime.Version())fmt.Println("elapsed time:", bench())
}

golang 1.21的结果

go run demo/large1_for.go
golang version: go1.21.5
elapsed time: 26.268µs

golang 1.22的结果

go run demo/large1_for.go
golang version: go1.22.1
elapsed time: 27.215µs

单次运行的结果发现1.21和1.22的消耗的时间是差不多的。
为什么第一个例子中1.22执行的时间长,1.21执行的时间短呢,因为1.21 for loop的变量只初始化一次,但是1.22 for loop的变量每次循环都会创建新的变量。因为在1.22的版本中不要在for loop中执行大尺寸的变量赋值

这篇关于loopvar 改动不同版本的影响-大循环的执行时间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/871807

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则