从现在开始,努力学习吧!本文《附加到作为空接口传递的 golang 切片》主要讲解了等等相关知识点,我会在编程网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容
从现在开始,努力学习吧!本文《附加到作为空接口传递的 golang 切片》主要讲解了等等相关知识点,我会在编程网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!
问题内容如何附加到空接口(已被验证为 *[]struct)?
func main() {
var myslice []mystruct // mystruct can be any struct (dynamic)
decode(&myslice, "...")
}
func decode(dest interface{}, src string) {
// assume dest has been verified to be *[]struct
var modeltype reflect.type = getstructtype(dest)
rows, fields := getrows(src)
for _, row := range rows {
// create new struct of type modeltype and assign all fields
model := reflect.new(modeltype)
for field := fields {
fieldvalue := getrowvalue(row, field)
model.elem().fieldbyname(field).set(fieldvalue)
}
castedmodelrow := model.elem().interface()
// append model to dest; how to do this?
// dest = append(dest, castedmodelrow)
}
}
我尝试过的事情:
这只是恐慌:reflect:在 ptr 值上调用reflect.append(因为我们传递 &myslice 而不是 myslice)
dest = reflect.append(reflect.valueof(dest), reflect.valueof(castedmodelrow))
这可以工作,但不会将值设置回目标...在主函数中,调用解码函数后 len(myslice) 保持为 0。
func decode(dest interface{}, src string) {
...
result := reflect.MakeSlice(reflect.SliceOf(modelType), rowCount, rowCount)
for _, row : range rows {
...
result = reflect.Append(result, reflect.ValueOf(castedModelRow))
}
dest = reflect.ValueOf(result)
}
以下是如何修复问题中显示的第二个 decode
函数。声明内容
dest = reflect.valueof(result)
修改局部变量dest
,而不是调用者的值。使用以下语句修改调用者的切片:
reflect.valueof(dest).elem().set(result)
问题中的代码将解码的元素附加在reflect.makeslice中创建的元素之后。生成的切片具有 len(rows)
零值,后跟 len(rows)
解码值。通过更改修复
result = reflect.append(result, reflect.valueof(castedmodelrow))
至:
result.index(i).set(model)
这是问题中第二个 decode
函数的更新版本:
func decode(dest interface{}, src string) {
var modeltype reflect.type = getstructtype(dest)
rows, fields := getrows(src)
result := reflect.makeslice(reflect.sliceof(modeltype), len(rows), len(rows))
for i, row := range rows {
model := reflect.new(modeltype).elem()
for _, field := range fields {
fieldvalue := getrowvalue(row, field)
model.fieldbyname(field).set(fieldvalue)
}
result.index(i).set(model)
}
reflect.valueof(dest).elem().set(result)
}
Run it on the Playground。
您与最初的解决方案非常接近。在调用追加操作之前,您必须取消引用指针。如果您的目标已经有一些现有元素并且您不想通过创建 newslice
来丢失它们,则此解决方案将很有帮助。
tempdest := reflect.valueof(dest).elem()
tempdest = reflect.append(tempdest, reflect.valueof(model.interface()))
与@i love reflection指出的类似,您最终需要将新切片设置回指针。
reflect.valueof(dest).elem().set(tempdest)
整体解码:
var modelType reflect.Type = getStructType(dest)
rows, fields := getRows(src)
tempDest := reflect.ValueOf(dest).Elem()
for _, row := range rows {
model := reflect.New(modelType).Elem()
for _, field := range fields {
fieldValue := getRowValue(row, field)
model.FieldByName(field).Set(fieldValue)
}
tempDest = reflect.Append(tempDest, reflect.ValueOf(model.Interface()))
}
reflect.ValueOf(dest).Elem().Set(tempDest)
终于介绍完啦!小伙伴们,这篇关于《附加到作为空接口传递的 Golang 切片》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~编程网公众号也会发布Golang相关知识,快来关注吧!
--结束END--
本文标题: 附加到作为空接口传递的 golang 切片
本文链接: https://lsjlt.com/news/596134.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0