当前位置: 首页 > article >正文

go 中指针的执行效率比较

package main
import (
    "fmt"
    "time"
)
type Books struct {
   title string
   author string
   subject string
   book_id int
}
func main() {
	start := time.Now() // 记录开始时间
   var Book1 Books        /* 声明 Book1 为 Books 类型 */
   var Book2 Books        /* 声明 Book2 为 Books 类型 */
   /* book 1 描述 */
   Book1.title = "Go 语言"
   Book1.author = "www.mei.biz"
   Book1.subject = "Go 语言教程"
   Book1.book_id = 6495407
   /* book 2 描述 */
   Book2.title = "Python 教程"
   Book2.author = "www.mei.biz"
   Book2.subject = "Python 语言教程"
   Book2.book_id = 6495700
   /* 打印 Book1 信息 */
   printBooks(Book1)
   /* 打印 Book2 信息 */
   printBooks(Book2)
   duration := time.Since(start) // 计算执行时间
   fmt.Printf("执行时间: %v\n", duration)
   // 记录 printBook 函数的执行时间
   bookStart := time.Now()
   /* 打印 Book1 信息(使用指针) */
   printBook(&Book1)
   /* 打印 Book2 信息(使用指针) */
   printBook(&Book2)
   bookDuration := time.Since(bookStart)
   fmt.Printf("printBook 函数执行时间: %v\n", bookDuration)
}

func printBooks( book Books ) {
   fmt.Printf( "Book title : %s\n", book.title)
   fmt.Printf( "Book author : %s\n", book.author)
   fmt.Printf( "Book subject : %s\n", book.subject)
   fmt.Printf( "Book book_id : %d\n", book.book_id)
}

func printBook( book *Books ) {
	fmt.Printf( "Book title : %s\n", book.title)
	fmt.Printf( "Book author : %s\n", book.author)
	fmt.Printf( "Book subject : %s\n", book.subject)
	fmt.Printf( "Book book_id : %d\n", book.book_id)
 }

第一次执行时:

go run .\strucd.go
Book title : Go 语言
Book author : www.runoob.com
Book subject : Go 语言教程
Book book_id : 6495407
Book title : Python 教程
Book author : www.runoob.com
Book subject : Python 语言教程
Book book_id : 6495700
执行时间: 1.7398ms
Book title : Go 语言
Book author : www.runoob.com
Book subject : Go 语言教程
Book book_id : 6495407
Book title : Python 教程
Book author : www.runoob.com
Book subject : Python 语言教程
Book book_id : 6495700
printBook 函数执行时间: 1.1665ms

看出指针传参时间执行较快,区别不大。
再执行:

Book title : Go 语言
Book author : www.mei.biz
Book subject : Go 语言教程
Book book_id : 6495407
Book title : Python 教程
Book author : www.mei.biz
Book subject : Python 语言教程
Book book_id : 6495700
执行时间: 1.0595ms
Book title : Go 语言
Book author : www.mei.biz
Book subject : Go 语言教程
Book book_id : 6495407
Book title : Python 教程
Book author : www.mei.biz
Book subject : Python 语言教程
Book book_id : 6495700
printBook 函数执行时间: 688.2µs
(µs 是微秒的符号,读作 “microsecond”。
1 微秒 = 1/1,000,000 秒 = 0.000001 秒
688.2µs = 0.0006882 秒)


http://www.kler.cn/news/358352.html

相关文章:

  • AI大模型开发架构设计(14)——基于LangChain大模型的案例架构实战
  • Windows环境apache控制台命令行启动、停止、重启httpd服务
  • 【Flutter】页面布局:线性布局(Row 和 Column)
  • mybatis针对枚举的处理的总结
  • 《Vue3 版本差异》Vue3.5+ 在组件或HTML元素绑定 ref 差异
  • (RAG 系列)重排序模型部署以及接入 fastgpt 平台
  • 【Flutter】页面布局:弹性布局(Flex)
  • Linux下的进程解析(level 2)
  • C++核心编程和桌面应用开发 第十二天(输入输出流 流对象 写文件 读文件)
  • 鸿蒙应用开发----西西购物商城(一)
  • G-Set(增长集合,Grow-Only Set)
  • 面试题:在 React 中如何绑定事件
  • 从 Microsoft 官网下载 Windows 10
  • Linux命令进阶·vi\vim编辑器详细命令介绍
  • vulnhub靶场之digitalworld.local: MERCY v2
  • maven多模块聚合打包父pom version占位符总无法install问题解决
  • 【C语言教程】【常用类库】(十六)正则表达式库 - <regex.h>
  • 七、朴素贝叶斯算法
  • Git核心概念图例与最常用内容操作(reset、diff、restore、stash、reflog、cherry-pick)
  • Web前端-JavaScript书写位置