草庐IT

json - 嵌套结构的解码字段不起作用

给定以下结构typeFoostruct{Thingtime.Duration`json:"thing"`}typeBarstruct{FooEntrytime.Duration`json:"entry"`}我想自定义time.Duration格式并从json字符串加载Bar值,例如:{"thing":"hour","entry":"second"}所以我为Foo和Bar(https://play.golang.org/p/6v71eG_Xr98)覆盖了UnmarshalJSON:packagemainimport("encoding/json""fmt""time")typeFoost

go - 从字节 slice 到不安全结构的类型转换

我试图理解为什么我在Go中的代码无法按我预期的方式工作。当我执行这个测试时,它失败了:funcTestConversion(t*testing.T){typemyTypestruct{auint8valueuint64}myVar1:=myType{a:1,value:12345}varcopyFrom[]bytecopyFromHeader:=(*reflect.SliceHeader)(unsafe.Pointer(©From))copyFromHeader.Data=uintptr(unsafe.Pointer(&myVar1))copyFromHeader.Cap=9c

go - 组合非类型化和类型化常量时的类型推断

当声明两个const变量(一个有类型和一个无类型),并打印出第二个的类型时,如:constxfloat32=10000consty=1e8/xfmt.Printf("thetypeofy:%T\n",y)//orwithreflect:fmt.Println(reflect.TypeOf(y))它告诉我,y是float32类型。嗯,这并不奇怪,因为非类型化常量变量y被定义为将非类型化浮点常量除以类型化浮点常量,因此可以推断类型。根据“GobyExample”(https://gobyexample.com/constants),常量永远没有类型,除非明确提供。然而,根据官方Go博客文档

go - 如何在 Go 中创建多级错误子类型

我试图在GO中创建错误的子类型。I'veaskedaquestionpreviously关于此事。现在我面临着多种类型的问题。以下代码显示错误类型定义:/*Interfaces*/typeUniversalErrorinterface{CommonError1}typeCommonError1interface{errorCommonError1()}/*Structs*/typeError1struct{reasonstring}typeError2struct{reasonstring}typeError3struct{reasonstring}/*Interfacefunctio

types - 我如何获得类型

我想从类型名称中获取(反射(reflect))类型。http://play.golang.org/p/c-9IpSafx0packagemainimport("fmt""reflect")typeNamestringfuncmain(){fmt.Println("Hello,playground")varnameName="Taro"fmt.Println(name)fmt.Println(getType(name))//fmt.Println(getType(Name))//wanttosameasgetType(name)}funcgetType(vinterface{})refl

types - 在 Go 中调用嵌入式类型的重载方法的正确方法

我有一个界面:packagepkgtypeBaseInterfaceinterface{funcNifty()boolfuncOther1()funcOther2()...funcOther34123()}以及实现它的结构:packagepkgtypeImplstruct{}func(Impl)Nifty()bool{...}然后是另一个想要嵌入第一个并做它自己的Nifty()的结构:packagemyOtherPackageimport"pkg"typeImplToostruct{*pkg.Impl}func(itImplToo)Nifty()bool{...somethingels

arrays - Golang append 到一个类型的 slice

我正在执行一个ldap查询,我想将结果填充到一个slice中。结果看起来像objectClass[toppersonorganizationalPersonuser]cn[user.1]sn[one]description[user.1]givenName[user]distinguishedName[CN=user.1,OU=random,DC=example,DC=com]...我正在尝试将其填充到map中,为此我创建了一个类型。typekeyvaluemap[string]interface{}现在我想创建一个这种类型的slice,以便多个用户的数据看起来像这样objectCla

golang代码组织: where should I put custom error types that are only relevant to one function?

我刚刚开始处理我的第一个golang项目,非常喜欢从函数返回自定义错误类型并在调用代码中使用类型断言来检查特定错误的想法。我发现这个解决方案比总是比较错误消息更清晰。我唯一的问题是:您最好将这些自定义错误类型放在哪里?假设许多自定义错误类型仅由一个实用程序函数使用(返回),它们应该与函数放在同一个包中吗?我应该以某种方式将它们分组吗?或者也许有更好的方法来做这种事情.. 最佳答案 “相同的包裹”是我最初的想法。在某些情况下,将它们放在不同的包中是有意义的,但只有当它们从多个包中的函数中合法地出现“相同的错误”时,并且这些包都不是逻辑

pointers - 将 reflect.AppendSlice 的结果分配给指针

我在将这段代码(实际上是在slice上左旋转)翻译成接受interface{}作为输入参数的更通用的版本时遇到了麻烦。funcrotate(a*[]int,iint){x,b:=(*a)[:i],(*a)[i:]*a=append(b,x...)}我在期末作业上遇到了麻烦:funcrotateSlice(ainterface{},iint){v:=reflect.ValueOf(a)x,b:=v.Elem().Slice(0,i),v.Elem().Slice(i,v.Elem().Len())*a=reflect.AppendSlice(b,x)}错误信息是invalidindire

go - 是否可以将 Type 存储在 map 中,稍后使用它在 Go lang 中实例化对象?

这个问题在这里已经有了答案:InstancenewType(Golang)(2个答案)关闭5年前。我是Go新手,遇到了这个问题。我需要制作一种“调度程序”,它将接收一个字符串并返回一个要基于该字符串实例化的类型。例如:AnimalType:=mymap["animal"]newAnimal:=new(AnimalType)有办法吗?提前致谢。