在下面的代码中,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(',')
}
}
}
答案 0 :(得分:1)
每次将参数传递给函数时,它都会在该函数内创建一个本地副本。当您传递指针时,该函数会收到该指针的副本,该副本指向相同的基础值。因此,如果您传递一个指针,该函数会影响它指向的值,然后调用者将看到该值。如果您改为传递值的副本(而不是传递指针),则该函数将操纵该副本,这对调用者自己的副本没有影响。