go 中指针的执行效率比较

时间:2024-10-21 14:39:35
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 秒)

相关文章