1 回答

TA貢獻(xiàn)2021條經(jīng)驗(yàn) 獲得超8個(gè)贊
如果你想修改傳遞的切片,它必須是一個(gè)指針,否則你必須返回一個(gè)新的切片。此外,如果函數(shù)被聲明為具有 type 的參數(shù)[]interface{},則只能傳遞 type 的值而不能傳遞[]interface{}其他切片類型......除非你使用泛型......
這是開(kāi)始使用 Go 1.18 中引入的泛型的完美示例。
更改DecodeMany()為通用的,T類型參數(shù)是切片元素類型:
拿指針時(shí)
func DecodeMany[T any](vv *[]T) error {
for _, g := range DoSomething() {
var v T
if err := gob.NewDecoder(bytes.NewReader(g.Buf)).Decode(&v); err != nil {
return err
}
*vv = append(*vv, v)
}
return nil
}
這是一個(gè)簡(jiǎn)單的應(yīng)用程序來(lái)測(cè)試它:
type MyType struct {
S int64
}
func main() {
var vv []MyType
if err := DecodeMany(&vv); err != nil {
panic(err)
}
fmt.Println(vv)
}
func DoSomething() (result []struct{ Buf []byte }) {
for i := 3; i < 6; i++ {
buf := &bytes.Buffer{}
v := MyType{S: int64(i)}
if err := gob.NewEncoder(buf).Encode(v); err != nil {
panic(err)
}
result = append(result, struct{ Buf []byte }{buf.Bytes()})
}
return
}
此輸出(在Go Playground上嘗試):
[{3} {4} {5}]
返回切片時(shí)
如果選擇返回切片,則不必傳遞任何內(nèi)容,但需要對(duì)結(jié)果進(jìn)行賦值:
func DecodeMany[T any]() ([]T, error) {
var result []T
for _, g := range DoSomething() {
var v T
if err := gob.NewDecoder(bytes.NewReader(g.Buf)).Decode(&v); err != nil {
return result, err
}
result = append(result, v)
}
return result, nil
}
使用它:
vv, err := DecodeMany[MyType]()
if err != nil {
panic(err)
}
fmt.Println(vv)
在Go Playground試試這個(gè)。
- 1 回答
- 0 關(guān)注
- 111 瀏覽
添加回答
舉報(bào)