日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

在Golang中,打印數(shù)組最有效的方法是使用fmt包中的Println函數(shù)。通過將數(shù)組作為參數(shù)傳遞給Println函數(shù),它會(huì)自動(dòng)將數(shù)組的內(nèi)容格式化并打印出來。這種方法非常簡(jiǎn)單且高效,適用于任何大小的數(shù)組。另外,Golang還提供了一些其他的打印數(shù)組的方法,例如使用strings包中的Join函數(shù)將數(shù)組元素連接成字符串后再打印出來,或者使用循環(huán)遍歷數(shù)組并打印每個(gè)元素。但相對(duì)而言,直接使用Println函數(shù)是最簡(jiǎn)單和最有效的方法。無論是在開發(fā)過程中還是調(diào)試時(shí),打印數(shù)組是一項(xiàng)非常常見的操作,掌握最有效的方法能夠提高開發(fā)效率。

問題內(nèi)容

我是編程新手,想了解有關(guān)內(nèi)置函數(shù)的更多信息:

這是程序:

func main() {
    start := time.now()

    fmt.println(os.args)

    fmt.println(time.since(start))
}

登錄后復(fù)制

及其輸出:

[a b c d e f g h i j k l m n o p] 124.009μs

這是我的 for 循環(huán):

package main

import (
"fmt"
"os"
"time"
)

func main() {
start := time.Now()

    var s string
    for i:=0; i<len(os.Args); i++{
        s += os.Args[i] + " " 
    }
    fmt.Println(s)
    
    fmt.Println(time.Since(start))

}

登錄后復(fù)制

輸出如下:

/tmp/go-build994847456/b001/exe/main a b c d e f g h i j k l m n o p 25.71μs

我希望標(biāo)準(zhǔn)庫(kù)中的內(nèi)置函數(shù)能夠更快。

切片會(huì)降低我的代碼效率嗎?

我應(yīng)該使用for循環(huán)還是標(biāo)準(zhǔn)庫(kù)fmt.println

我也很困惑 strings.join(os.args\[1:\], " ") 如何執(zhí)行 74.293μs

解決方法

使用基準(zhǔn):

var slice = []string{"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p"}

func benchmarkfmt(b *testing.b) {
    b.reportallocs()
    for n := 0; n < b.n; n++ {
        _ = fmt.sprint(slice)
    }
}

func benchmarkstringconcat(b *testing.b) {
    b.reportallocs()
    for n := 0; n < b.n; n++ {
        var str string
        for _, s := range slice {
            str += s + " "
        }
    }
}

func benchmarkstringsbuilder(b *testing.b) {
    b.reportallocs()
    for n := 0; n < b.n; n++ {
        var l int
        for _, s := range slice {
            l += len(s)
        }
        var sb strings.builder
        sb.grow(l + len(slice)*len(" "))
        for _, s := range slice {
            sb.writestring(s)
            sb.writestring(" ")
        }
        _ = sb.string()
    }
}

func benchmarkstringsjoin(b *testing.b) {
    b.reportallocs()
    for n := 0; n < b.n; n++ {
        _ = strings.join(slice, " ")
    }
}

登錄后復(fù)制

BenchmarkFMT
BenchmarkFMT-8                    734088          1633 ns/op         616 B/op         34 allocs/op
BenchmarkStringConcat
BenchmarkStringConcat-8          1290666           919.1 ns/op      1200 B/op         32 allocs/op
BenchmarkStringsBuilder
BenchmarkStringsBuilder-8        6074888           198.6 ns/op        64 B/op          1 allocs/op
BenchmarkStringsJoin
BenchmarkStringsJoin-8           4941542           241.7 ns/op        64 B/op          1 allocs/op
PASS

登錄后復(fù)制

分享到:
標(biāo)簽:標(biāo)準(zhǔn)庫(kù)
用戶無頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定