Go语言中字符串拼接的方法总结

 更新时间:2023年11月24日 09:00:36   作者:小邓的编程日记  
在Go语言中,我们可以使用+操作符、bytes.Buffer、strings.Builder等方法来拼接字符串,本文主要为大家介绍了这些常用方法的实现以及性能对比,感兴趣的小伙伴可以了解下

在日常开发中,每位开发人员都会面临连接字符串的任务。在Go语言中,我们可以使用+操作符、bytes.Bufferstrings.Builder等方法来拼接字符串。

基准测试

为了对比这些方法的性能,我编写了下面的基准测试代码:

package main  
  
import (  
    "bytes"  
    "strings"    
    "testing"
)  
  
func BenchmarkConcat(b *testing.B) {  
    var str string  
    for n := 0; n < b.N; n++ {  
       str += "x"  
    }  
    b.StopTimer() 
}  
  
func BenchmarkBuffer(b *testing.B) {  
    var buffer bytes.Buffer  
    for n := 0; n < b.N; n++ {  
       buffer.WriteString("x")  
    }  
    b.StopTimer()
}  
  
func BenchmarkCopy(b *testing.B) {  
    bs := make([]byte, b.N)  
    bl := 0  
  
    b.ResetTimer()  
    for n := 0; n < b.N; n++ {  
       bl += copy(bs[bl:], "x")  
    }  
    b.StopTimer() 
}  

func BenchmarkBuilder(b *testing.B) {  
    var str strings.Builder  
    for n := 0; n < b.N; n++ {  
       str.WriteString("x")  
    }  
    b.StopTimer() 
}

在命令行,进入到测试文件所在目录,执行命令:

go test -bench=Benchmark* -benchmem

等待一会,输出测试结果:

BenchmarkConcat-20       1000000             64276 ns/op          503995 B/op          1 allocs/op
BenchmarkBuffer-20      349817613                3.283 ns/op           3 B/op          0 allocs/op
BenchmarkCopy-20        705887335                1.714 ns/op           0 B/op          0 allocs/op
BenchmarkBuilder-20     637184155                2.125 ns/op           5 B/op          0 allocs/op

`` 上面的测试结果显示了四种连接字符串的性能。

+操作符:

分析:

  • 执行时间:64,276 纳秒/op
  • 内存分配:503,995 字节/op
  • 分配次数:1 次/op
  • 使用 += 运算符进行字符串拼接,它在每次迭代都会创建一个新的字符串,导致较大的内存分配和分配次数。
  • 总体而言,这种方法的性能相对较差。

bytes.Buffer:

分析:

  • 执行时间:3.283 纳秒/op
  • 内存分配:3 字节/op
  • 分配次数:0 次/op
  • 使用 bytes.Buffer 类型,这是一种性能较好的字符串拼接方法。
  • 它几乎没有内存分配,并且执行时间非常短,是一种高效的拼接方式。

Copy:

分析:

  • 执行时间:1.714 纳秒/op
  • 内存分配:0 字节/op
  • 分配次数:0 次/op
  • 使用 copy 函数,直接在预分配的字节数组上进行拷贝。
  • 具有最低的执行时间和零内存分配,是最高效的字符串拼接方式。

strings.Builder:

分析:

  • 执行时间:2.125 纳秒/op
  • 内存分配:5 字节/op
  • 分配次数:0 次/op
  • 使用 strings.Builder 类型,性能介于 bytes.Buffercopy 之间。
  • 有一些内存分配,但仍然是一种有效的拼接方法。

总结:

  • 在这个基准测试中,copy 函数的性能最佳,其次是 bytes.Bufferstrings.Builder,而使用 += 运算符的性能最差。
  • 在选择字符串拼接方法时,应根据实际需求和性能要求选择适当的方式,避免不必要的内存分配,提高程序执行效率。
  • 使用strings.Builder兼顾了用法和性能,是一种值得推荐的拼接方式。

测试代码 gobyexample/string-concat/string_concat_test.go at master · denglei1024/gobyexample (github.com)

到此这篇关于Go语言中字符串拼接的方法总结的文章就介绍到这了,更多相关Go字符串拼接内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • golang开发中channel使用

    golang开发中channel使用

    channel[通道]是golang的一种重要特性,正是因为channel的存在才使得golang不同于其它语言。这篇文章主要介绍了golang开发中channel使用,需要的朋友可以参考下
    2020-09-09
  • 关于Golang标准库flag的全面讲解

    关于Golang标准库flag的全面讲解

    这篇文章主要介绍了关于Golang标准库flag的全面讲解,这个库的代码量只有1000行左右,却提供了非常完善的命令行参数解析功能,更多相关内容需要的朋友可以参考一下
    2022-09-09
  • golang gorm 操作mysql及gorm基本用法

    golang gorm 操作mysql及gorm基本用法

    golang 官方的那个操作mysql的有点麻烦所以就使用了gorm,下面就gorm的使用做下简单介绍,感兴趣的朋友跟随小编一起看看吧
    2018-11-11
  • 深入分析golang多值返回以及闭包的实现

    深入分析golang多值返回以及闭包的实现

    相对于C/C++,golang有很多新颖的特性,例如goroutine,channel等等,这些特性其实从golang源码是可以理解其实现的原理。今天这篇文章主要来分析下golang多值返回以及闭包的实现,因为这两个实现golang源码中并不存在,我们必须从汇编的角度来窥探二者的实现。
    2016-09-09
  • Go语言数据结构之插入排序示例详解

    Go语言数据结构之插入排序示例详解

    这篇文章主要为大家介绍了Go语言数据结构之插入排序示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 基于Go语言实现插入排序算法及优化

    基于Go语言实现插入排序算法及优化

    插入排序是一种简单的排序算法。这篇文章将利用Go语言实现冒泡排序算法,文中的示例代码讲解详细,对学习Go语言有一定的帮助,需要的可以参考一下
    2022-12-12
  • go中new和make的区别小结

    go中new和make的区别小结

    new 只分配内存,make 用于初始化 slice、map 和 channel,本文详细的介绍了go中new和make的区别小结,感兴趣的可以了解一下
    2023-05-05
  • Go标准库日志打印及同时输出到控制台与文件

    Go标准库日志打印及同时输出到控制台与文件

    Go语言内置的log包实现了简单的日志服务,下面这篇文章主要给大家介绍了关于Go标准库日志打印及同时输出到控制台与文件的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • golang实现http服务器处理静态文件示例

    golang实现http服务器处理静态文件示例

    这篇文章主要介绍了golang实现http服务器处理静态文件的方法,涉及Go语言基于http协议处理文件的相关技巧,需要的朋友可以参考下
    2016-07-07
  • 利用Golang实现对配置文件加密

    利用Golang实现对配置文件加密

    在实际的应用中,配置文件通常包含了一些敏感的信息,如数据库密码、API密钥等,为了保护这些敏感信息不被恶意获取,我们可以对配置文件进行加密,本文将介绍如何使用Go语言实现对配置文件的加密,需要的朋友可以参考下
    2023-10-10

最新评论