jjzjj

pointers - 确认 Go 中的结构字段非零

我正在尝试编写一个通用函数,它采用struct并确认给定字段具有非零值。这是我的功能:funcCheckRequiredFields(kindstring,iinterface{},fields...string)error{for_,field:=rangefields{value:=reflect.ValueOf(i).FieldByName(field)ifvalue.Interface()==reflect.Zero(value.Type()).Interface(){returnfmt.Errorf("missingrequired%sfield%s",kind,field)

golang - 将 [ ] 接口(interface)转换为 [ ] 字符串或连接字符串

如何将[]interface转换为[]strings或将其转换为包含[]interface中所有元素的连接的单个字符串?下面是显示“scope”的精确值的屏幕截图,[]interface类型的长度为2。在下面的代码中,case是“slice”,目前我正在使用reflect进行此操作,但这看起来不太好。想知道应该有一些好的方法来连接界面元素的slice\数组。我也试过像这样使用jsonunmarshall"json.Unmarshal([]byte(jwtResp),&mymap)"但在将jwt.MapClaims转换为byte[]时遇到类型问题parsedkey,_:=jwt.Pars

go - 如何在 reflect.New 创建时按其类型转换 reflect.Value

我实际上是在尝试在golang中使用反射的黑魔法:P我得到了这样的东西:var_intintvar_int32int32var_int64int64var_stringstringvarnilablesIndexmap[int]reflect.Valuevarnilables=map[string]reflect.Type{"int32":reflect.TypeOf(_int32)},"int64":reflect.TypeOf(_int64)},"int":reflect.TypeOf(_int)},"string":reflect.TypeOf(_string)},}nilabl

go - 一个通用的 golang 装饰器(要点需要澄清)

有人可以解释这个要点中发生了什么吗?我了解装饰器的概念以及此实现如何让人们创建通用装饰器,但我在几个部分(内联评论)中几乎没有迷失。如果有人能为我分解它,我将不胜感激。此外,如果这不是编写通用装饰器的最佳方式,那什么才是?我正在寻找一种装饰器,它可以装饰func(args...interface{})(interface{},error)类型的函数,而不会丢掉类型安全性。https://gist.github.com/saelo/4190b75724adc06b1c5apackagemainimport("fmt""reflect")funcDecorate(implinterface

pointers - 当字段是指向 x 的指针时,使用反射设置结构字段的值

我有一个指向各种基元的指针结构。该结构是应用程序的配置,字段是指针的原因是这样我可以确定设置为默认值的字段和根本未设置的字段-以强制执行“必需”字段。这是一个简单的例子:typeConfigstruct{A*stringB*intC*boolD*[]string//wildcard!}因此,我通过reflect.ValueOf(*cfg)获取了reflect.Value,这为我提供了每个元素上的.Field,我遍历。问题是,每个元素都不通过CanAddr或CanSet,我似乎无法找到一种方法来设置指针后面的值。这是语言的限制吗?我需要让我的字段成为非指针吗?那会很糟糕,因为无法确定用户

go - 如何动态创建一个少一个属性的结构体?

有没有办法复制通用结构(即属性名称未知的结构)并跳过单个已知属性?这是我知道的:我的函数的参数——我将调用参数myData——是interface{}类型。myData是一个结构。myData有一个已知属性path。myData有0到6个左右的其他属性,没有一个是先验已知的。一旦我删除了path属性,“剩余”就是30种可能的结构类型之一。所以我想从myData中删除path(或者更准确地说,制作一个省略path的副本),以便生成的各种位尝试将结构强制为其可能类型之一的代码将能够成功。我找到了通过反射复制结构的示例,但它们通常创建一个空结构具有相同的基础类型,然后填充它。所以甚至可以删除

go - 使用反射设置 nil *int32 结构字段

我正在尝试通过反射设置nil*int的值。在下面的示例中,replaceNilWithNegativeOne应该替换任何nil*int32字段(标记为grib:"foo")和一个指向-1的指针。但是,当代码运行时,reflect会出现panic,并显示panic:reflect:reflect.Value.Setusingunaddressablevalue。我在其他几个地方看到了几乎与我在这里问的完全相同的问题,例如:Usingreflect,howdoyousetthevalueofastructfield?Usingreflect,howdoyouinitializevalueo

go - 是否可以通过Golang中的枚举类型反射(reflect)出枚举的变量

例如,我有一个像这样的枚举:typeStatusintconst(NormalStatus=itoaBlocked)Status的类型已知,我可以通过Status获取"Normal"和"Blocked"。如果有一种方法,我想就是通过reflect。我不想用映射来解决它。因为这个函数是在一个库中使用的。它是一种无状态的。还有其他方法吗?谢谢 最佳答案 常量名称不会在reflectAPI中公开。使用stringer工具。 关于go-是否可以通过Golang中的枚举类型反射(reflect)出

go - 从 reflect.Type 中删除指针

我有一个reflect.Type,它包含一个指向结构的双指针。我希望能够删除一个间接级别以获得指向该结构的指针。这可能吗?例如,我想这样做:funcfoo(xinterface{}){typ:=reflect.TypeOf(x)fmt.Printf("%v",typ)//prints**FoorealType:=typ.PointsTo()fmt.Printf("%v",typ)//prints*Foo}但据我所知,这个功能并不存在。有一个Indirect函数在Value上运行,但我看不到任何类似的适用于Type的函数。 最佳答案

go - 在go中,为什么打印出来的reflected value和它的interface一样?

摘自LawsofReflection:(Whynotfmt.Println(v)?Becausevisareflect.Value;wewanttheconcretevalueitholds.)这让我很困惑,因为下面的代码:varxfloat64=3.4varv=reflect.ValueOf(x)fmt.Println("valueofxis:",v)y:=v.Interface().(float64)//ywillhavetypefloat64.fmt.Println("interfaceofvalueofxis:",y)打印相同的输出:valueofxis:3.4interfac