string 和byte.Buffer的巨大差别

package main

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

const num = 100000 * 5

func testString() (t int64) {
    var s string
    start := time.Now().UnixNano()
    for i := 0; i < num; i++ {
        s += "a"
    }
    return time.Now().UnixNano() - start
}
func testBuf() (t int64) {
    var s bytes.Buffer
    start := time.Now().UnixNano()
    for i := 0; i < num; i++ {
        s.WriteString("a")
    }
    return time.Now().UnixNano() - start
}
func main() {
    fmt.Printf("string ----->%d ms\n", testString()/1e6)
    fmt.Printf("buffer ----->%d ms\n", testBuf()/1e6)
}

结果


屏幕快照 2016-12-08 下午7.53.23.png

可以看到差别巨大..
分析原因如下:

  • string 不可变,每次运算都要分配新的内存把数据拷贝到新的内存中
  • byte.Buffer会有预分配, 要合适的时候才会扩大内存,并把原来的数据拷贝过去
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,303评论 6 13
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,418评论 11 349
  • 1.项目经验 2.基础问题 3.指南认识 4.解决思路 ios开发三大块: 1.Oc基础 2.CocoaTouch...
    阳光的大男孩儿阅读 5,099评论 0 13
  • *面试心声:其实这些题本人都没怎么背,但是在上海 两周半 面了大约10家 收到差不多3个offer,总结起来就是把...
    Dove_iOS阅读 27,270评论 30 472
  • 原本是一个双头的,但是由于根部杆子干枯了,分成了两个头。这个头姑且叫做命运①号好了!
    卡蜜娅养肉ing阅读 186评论 0 0