golang各种字符串拼接性能对比

yushu1987 · · 7731 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

golang中字符串拼接方法

  1. +=
  2. fmt.sprintf
  3. append
  4. buffer.WriteString
  5. copy

废话不多说,直接上代码看效果

package main

import (
    "bytes"
    "fmt"
    "time"
)

func main() {
    str:="chinese"
    city:="beijing"
    
    // 1. +=
    s:=time.Now()
    for i:=0;i<100000;i++ {
        str +=city
    }
    e:=time.Since(s)
    fmt.Println("time cost 1:", e)
  
    // 2. fmt.Sprintf
    str="chinese"
    city="beijing"
    s=time.Now()
    for i:=0;i<100000;i++ {
        str = fmt.Sprintf("%s%s",str,city)
    }
    e=time.Since(s)
    fmt.Println("time cost 2:", e)
  
     //3.  buffer.WriteString
    str="chinese"
    city="beijing"
    s=time.Now()
    var buf= bytes.Buffer{}
    buf.WriteString(str)
    for i:=0;i<100000;i++ {
        buf.WriteString(city)
    }
    e=time.Since(s)
    fmt.Println("time cost 3:", e)

   //4. append
    str="chinese"
    city="beijing"
    s=time.Now()
    bstr:=[]byte(str)
    bcity:=[]byte(city)
    for i:=0;i<100000;i++ {
        bstr= append(bstr, bcity...)
    }
    e=time.Since(s)
    fmt.Println("time cost 4:", e)

  // 5. copy
    str="chinese"
    city="beijing"
    s=time.Now()
    zstr :=[]byte(str)
    for i:=0;i<100000;i++ {
        copy(zstr, city)
    }
    e=time.Since(s)
    fmt.Println("time cost 5:", e)
}

最终效果(多次尝试,对比结果都一致):

time cost 1: 3.176250251s
time cost 2: 5.347827717s
time cost 3: 1.051104ms
time cost 4: 769.258µs
time cost 5: 323.968µs

效率:copy > append > buf.WriteString > += > fmt.Sprintf
所以请慎用fmt.Sprinf 和 +=


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:yushu1987

查看原文:golang各种字符串拼接性能对比

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

7731 次点击  
加入收藏 微博
1 回复  |  直到 2019-09-21 10:42:40
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传