草庐IT

Transforms类型

全部标签

reflection - Golang - 扫描所有类型的结构

我是围棋初学者。我可能认为多年来使用其他语言太传统了,但这就是我想在Go中做的事情。假设以下用例我有接口(interface)I。这个接口(interface)有函数,start()和stop()有许多实现接口(interface)的结构。结构A,结构B,结构C当应用程序启动时,我想在结构A、B和C上调用start()同样,当应用程序终止时,我想对A、B、C结构调用stop()。我不想在代码中的任何地方对结构A、B和C进行硬编码以调用启动/停止函数。这样当我稍后添加结构D(也实现接口(interface)I)时,代码将自动运行而无需修改。为了实现这一目标,我需要能够说“嘿,给我所有实现

string - 我如何转换并附加到 Golang 中的一段字符串,一个来自 go-ping 存储库的网络类型变量?

这是完整的代码,与您在gitrepo页面上找到的代码没有太大区别。packagemainimport("fmt""github.com/go-ping""time")varstats=[][]string{nil}funcpinging(domainstring,intervalint,unitstring,exitint){current_time:=time.Now().Local()current_time.Format("02-01-2000")switchunit{case"ms":interval*=1case"sec":interval*=1000case"min":in

Golang 嵌入式结构类型

我有这些类型:typeValueinterface{}typeNamedValuestruct{NamestringValueValue}typeErrorValuestruct{NamedValueErrorerror}我可以使用v:=NamedValue{Name:"fine",Value:33},但我不能使用e:=ErrorValue{名称:“alpha”,值:123,错误:err}好像嵌入语法没问题,但是用起来不行? 最佳答案 嵌入式类型是(未命名的)字段,由非限定类型名称引用。Spec:Structtypes:Afield

go - 如何断言一个空接口(interface)回到我的自定义类型的一部分?

我在这个应用程序中有15个自定义类型,我希望对它们进行的处理实际上对它们都非常通用。在每种情况下,我都需要迭代我正在使用的任何类型的slice。接口(interface)是当前通过的,但它当然不必保持这种状态我有以下代码:funcProcessSlice(ininterface{}){switchreflect.TypeOf(p.in).Kind(){casereflect.Slice:s:=reflect.ValueOf(p.in)fori:=0;ifmt.Println用于调试,我得到以下类型的输出:[map[_Id:4K7qx_mUSbV-----------==name:_cl

go - [][]*数据类型在golang中是什么意思

假设这是我的示例代码。运行时输出[[]][[][]][[][][]][[][][][]]。帮助我理解这段代码描述的内容以及编程术语中称为routingtable[][]*node的内容。它是节点的slice还是节点类型的二维数组。如果我听起来很蠢,请原谅我,但我只是想学习。packagemainimport"fmt"typenodestruct{idint}funcmain(){varroutingtable[][]*nodefori:=0;i 最佳答案 它只是意味着它包含4个空节点指针slice,这是您的代码的预期行为。它是一片片

go - 不可能类型开关案例 : ErrorType (type reflect. 类型)不能有动态类型 *os.SyscallError(缺少对齐方法)

尝试确定连接错误是什么并将值返回给程序。d:=net.Dialer{Timeout:20*time.Second}conn,errors:=d.Dial("tcp",fmt.Sprintf("%v:%v",host,port))iferrors!=nil{ifoerr,ok:=errors.(*net.OpError);ok{ErrorType:=reflect.TypeOf(oerr.Err)switchErrorType.(type){case*os.SyscallError:fmt.Println("connect:connectiontimedoutto",host,"onpo

go - 如何使用 golang 中的函数将 interface{} 值转换为静态类型值?

在标准库中,我可以使用指针将JSON转换为类型化对象。现在的问题是,我如何创建类似json.Marshal的方法来将vinterface{}转换为类型化对象?我是否需要在执行此操作时使用reflect?请看下面的代码片段,我正在寻找可以填写home包中的TODO的人。谢谢。packagemainimport("encoding/json""fmt""./home")typeDogstruct{NamestringFavoriteGamestring}func(dogDog)Greet(){dog.Bark()}func(dogDog)Bark(){iflen(dog.Name)==0{

pointers - 为什么接口(interface)类型不提供 "IsNil"方法?

首先让我们考虑以下几点:funcprocess(bodyio.Reader){fmt.Printf("body==nil?%+v\n",body==nil)}funcmain(){varbody*bytes.Bufferfmt.Printf("body==nil?%+v\n",body==nil)process(body)process(nil)}这是输出:body==nil?truebody==nil?false//Didyougetthisright?body==nil?true另一个例子:typeContainerstruct{Readerio.Reader}funcproces

go - 避免在类型转换的分支中使用类型断言

我在Go中使用类型开关,例如以下一个:switchquestion.(type){caseinterfaces.ComputedQuestion:handleComputedQuestion(question.(interfaces.ComputedQuestion),symbols)caseinterfaces.InputQuestion:handleInputQuestion(question.(interfaces.InputQuestion),symbols)}有什么方法可以防止我必须先断言案例中的问题类型,然后才能将其传递给另一个函数? 最佳答案

go - Ref "is not a type"- 在结构中存储类型

我有这样一个文件:packagefootypeHandlerstruct{}然后在另一个文件中,我有:import("handlers/foo""handlers/bar""handlers/baz")typeAllHandlersstruct{Foofoo.HandlerBarbar.HandlerBazbaz.Handler}然后在另一个文件中我有:all:=routes.AllHandlers{}foo:=all.Foo{}bar:=all.Bar{}baz:=all.Baz{}但它给了我这个错误:Fooisnotatype我可能犯了一些严重错误。我想要做的是将所有处理程序存储在