传递给另一个函数时,为什么需要指向Go bytes.Buffer的指针?

时间:2018-08-31 15:53:05

标签: pointers go

在下面的代码中,write_commas要求buffer参数是一个指针。可以。

替代方法(即不使用指针)导致空白输出。

为什么通过实际的bytes.Buffer无法打印任何内容?或者换种说法,传递实际的bytes.Buffer是否会创建一个副本,从而将字节写入没有读取内容的缓冲区?

package main

import (
    "fmt"
    "bytes"
)

func main() {
    s := "1234567898"
    fmt.Println(Comma(s))

}

func Comma(s string) string {
    var buf bytes.Buffer  // <-- bytes.Buffer declared here.
    sbytes := []byte(s)
    decimal := bytes.LastIndex(sbytes,[]byte("."))
    if decimal > 0 {
        whole_part := sbytes[:decimal]
        write_commas(whole_part, &buf)  // <-- Address

        float_part := sbytes[decimal:len(sbytes)]
        for i := len(float_part); i > 0; i-- {
            buf.WriteByte(float_part[len(float_part)-i])
        }
    } else {.
        write_commas(sbytes, &buf)  // <-- Address
    }

    return buf.String()
}

func write_commas(byr []byte, buf *bytes.Buffer) { // <-- Why *bytes.Buffer?
    for i := len(byr); i > 0; i-- {
        buf.WriteByte(byte(byr[len(byr)-i]))
        if i > 1 && (i-1) % 3 == 0 {
            buf.WriteByte(',')
        }
    }
}

1 个答案:

答案 0 :(得分:1)

每次将参数传递给函数时,它都会在该函数内创建一个本地副本。当您传递指针时,该函数会收到该指针的副本,该副本指向相同的基础值。因此,如果您传递一个指针,该函数会影响它指向的值,然后调用者将看到该值。如果您改为传递值的副本(而不是传递指针),则该函数将操纵该副本,这对调用者自己的副本没有影响。