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

问题描述 投票:-1回答:1

在下面的代码中,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(',')
        }
    }
}
pointers go
1个回答
1
投票

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

© www.soinside.com 2019 - 2024. All rights reserved.