草庐IT

TS-枚举类型enum

全部标签

go - 在 Go 中是否有一种惯用的方法来通过类型断言的接口(interface)进行索引?

我正致力于在Go中实现并发的string和byte阅读器。这样做的目的是允许解析newline和读取字符串中的其他此类字节。在研究这个问题时,我发现了在单值上下文中处理多个值的各种方法1,但是这些都没有处理混合类型的出现。有人建议使用接口(interface)来处理这个问题2,并且已经尝试过,但我对现有建议的冗长冗长感到不舒服3和4.我想知道是否有一种惯用的方法可以以整洁的方式有效地对各种类型的值进行排序。已编辑:首先,我按照建议建立了一个界面。这似乎是个好主意,如果我记得的话,这是C中常用的技巧。funcUse(vals...interface{}){i:=0p:=[]uint8{}

go - 如何将父类型转换为子类型

给定以下类型:type(Parentstruct{namestringsurnamestring}Childstruct{*ParentsportString})...func(p*Parent)GetSport()string{return((*Child)(p)).sport//doesnotwork}如何将*Parent转换为*Child? 最佳答案 func(p*Parent)Convert()*Child{return&Child{p,""}}https://play.golang.org/p/saGvRu_rIk问题是没

json 和类型转换

我正在尝试读取一个看起来像这样的json文件[{"title":"hi","tags":[1,2,3,4,5,6]},{...},{...}]代码是这样的contentdat,err:=ioutil.ReadFile("content.json")check(err)varcontent[]interface{}err=json.Unmarshal(contentdat,&content)check(err)fori,contentItem:=rangecontent{vertedContentItem:=contentItem.(map[string]interface{})cont

go - main包中类型struct的名称首字母大小写

所以如果没有导入的话应该是小写的。从主包中导入一些东西很奇怪。但是,根据其他语言的经验,对我来说使用小写字母作为结构/类的第一个看起来很奇怪。什么方式是惯用的? 最佳答案 这不是什么是惯用的问题,如果标识符以小写字母开头,则不会导出,因此只能从声明包(直接)访问,如果标识符以大写字母开头(Unicode类“Lu”),它是导出的,可以从任何包中引用。有关详细信息,请参阅Spec:Exportedidentifiers.这是一个我个人喜欢的设计决定(它保持源代码干净,“它们甚至具有语义效果:名称在包外的可见性取决于它的第一个字符是否大写

尝试附加相同类型的结构时,Go 返回错误

我在尝试使用追加函数合并两个结构时遇到错误:./test.go:33:18:cannotuseconfigs(typeMapUsers)astypestruct{Userarnstring"yaml:\"userarn\"";Usernamestring"yaml:\"username\"";Groups[]string"yaml:\"groups\""}inappend这是代码。packagemainimport("fmt""gopkg.in/yaml.v2""io/ioutil""os")typeMapUsers[]struct{UserarnstringUsernamestrin

pointers - 初始化指针数组 - 无法创建类型 *[]type

它是一个简单的代码,将car类型的对象保存到一个car类型的数组中。我在这里尝试使用指针来传递数组引用。有2个问题:1-我无法将其初始化为空数组。当我使用make时,它说:cannotmaketype*[]car2-如果我不使用make,会出现运行时错误:panic:runtimeerror:invalidmemoryaddressornilpointerdereference代码:import"fmt"typecarstruct{platestringcolorstring}funcmain(){var_cars*[]car//listofcars_cars=make(*[]car,

go - 我可以在 go 中使用什么数字类型来获得最大的数字?

假设如下:packagemainimport("fmt")funcmain(){varMaxIntuint64MaxInt=1我得到的结果是:Type:uint64Value:18446744073709551615正如预期的那样。但是,假设我想要更大的,比如1,当我使用funcmain(){x:=1我得到:./prog.go:10:10:constant115792089237316195423570985008687907853269984665640564039457584007913129639936overflowsint对于x:=1我得到:./prog.go:10:10:s

unit-testing - 如何断言 Go 测试中的错误类型?

我有一个如下定义的错误类型typeRetryableErrorstruct{msgstring}func(a*RetryableError)Error()string{returna.msg}在单元测试中,如果返回的错误是RetryableError类型,Go的断言方式是什么? 最佳答案 使用类型断言:err:=someFunc()ifretryable,ok:=err.(RetryableError);ok{//useretryable}您的RetryableError不是错误,但*RetryableError是。更正:func(

pointers - 不同类型的指针之间有什么区别?

指针指向内存中的一个位置。据我所知,实际上所有内存地址都具有相同的类型,与变量类型无关。除了使用不同的指针类型(*int、*string等),是否可以只使用一种类型(varppointer)所有指针类型?不同的指针类型有什么区别?packagemainimport"fmt"funcmain(){i:=5s:="abc"varpi*int//alternativelyvarpipointervarps*string//alternativelyvarpspointerpi=&ips=&sfmt.Printf("%p%p",pi,ps)//resultis0x1040e0f80x1040a

select - 从非 chan 类型 time.Duration 接收

在thistutorial提供以下示例:funcLongRunningHandler(ctxcontext.Context)string{deadline,_:=ctx.Deadline()for{select{case当我编译此代码时出现以下错误:invalidoperation:示例中的代码有什么问题? 最佳答案 用于从channel接收,为此既不time.Until或Truncate返回一个channel。在这种情况下,错误消息是在识别问题,但并没有真正说明实际需要采取哪些不同的措施。go确实提供了一些返回channel的时间