草庐IT

map函数

全部标签

json - Go 能够解码为 map[string][]interface{} 吗?

目前,我尝试将JSON解析为map[string][]interface{},但解码返回错误。根据(https://golang.org/pkg/encoding/json/),为了将JSON解码为接口(interface)值,Unmarshal将其中之一存储在接口(interface)值中:bool,用于JSONbool值float64,用于JSON数字string,用于JSON字符串-[]接口(interface){},用于JSON数组map[string]interface{},用于JSON对象nil表示JSONnull我想知道golang是否能够解码map[string][]i

go - 列出源代码中的所有函数

我有一个文件夹,其中包含.go文件和在其中定义的函数。是否可以在命令行中列出当前文件夹中的所有函数声明,可能使用godoc?godoclistfunctions/path/to/fileOrFolder要有这样的输出:funcFoo(a,bint)intfuncBar(c,dint)int 最佳答案 当然,Peter的回答已经足够了,但是如果你想进入兔子洞……而且是为了好玩。使用golangstdlibast的强大功能。packagemainimport("fmt""go/ast""go/parser""go/token""io/i

go - 将 json 文件传递​​给 GoLang 函数

刚开始使用Go。我有一个如下所示的Go函数,我必须向它传递一个json文件。如何将json文件引用传递给此函数,即接受它作为接口(interface)映射?funccompressOIds(mapDocumentmap[string]interface{})string{varobjectIdValuestringforkey,value:=rangemapDocument{....}return""} 最佳答案 如果您的JSON结构定义不明确并且可以更改,那就是要走的路:import("fmt""encoding/json")fu

go - 为什么并发不能加速我的斐波那契函数?

这是Go之旅中的以下并发示例packagemainimport("fmt")funcfibonacci(nint,cchanint){x,y:=0,1fori:=0;i我将其修改为不使用goroutines:packagemainimport("fmt")funcfibonacci(nint)int{if(n==0||n==1){return1}x:=1y:=1fori:=0;i然而,在n=100000时,它所花费的时间几乎都是瞬间的。有没有人有goroutines加速计算的例子?我想知道是否有一些编译器设置限制了我的程序可以使用的内核数量。为什么goroutines不能加速计算?

go - 当作为参数传递给单独包中的函数时,结构不是类型

我正在制作一个JSON验证函数并尝试实现它。但是,当我尝试将它们作为参数导入我的验证函数时,我的结构出现了问题,该验证函数位于另一个包中。它在另一个包中的原因是因为我将在不同的路由文件中调用一个通用验证函数,所以我实际上不能在该包中包含任何结构,它们必须在路由文件中导入和定义。typeUsersJSONstruct{Usersstruct{Put[]UserJSON`json:"PUT"`}`json:"users"`}typeUserJSONstruct{display_namestring`json:"display_name"`usernamestring`json:"usern

pointers - 为什么在将它传递给另一个函数时需要指向 Go bytes.Buffer 的指针?

在下面的代码中,write_commas要求缓冲区参数是一个指针。它有效。替代方案(即不使用指针)会导致空白输出。为什么传递实际的bytes.Buffer无法打印任何内容?或者换句话说,传递实际的bytes.Buffer是否会创建一个副本,从而将字节写入一个没有任何内容正在读取的缓冲区?packagemainimport("fmt""bytes")funcmain(){s:="1234567898"fmt.Println(Comma(s))}funcComma(sstring)string{varbufbytes.Buffer//0{whole_part:=sbytes[:decima

go - 我们如何创建一个空 map 并在 golang 中附加新数据?

我在创建一个空map并在另一个map上循环时向其附加新数据时遇到问题。这是我在IDE上遇到的错误。这是我要添加到map的数据结构。typeOutcomestruct{QuestionIndexstringChoiceIndexint64Correctbool}funccreateEntryOutcome(e*entry.Entry)map[string]interface{}{entryPicks:=e.Live.Picksoutcomes:=make(map[string]interface{})foridx,pick:=rangeentryPicks{mappedPick:=pic

pointers - 无法附加到函数内的 slice

这个问题在这里已经有了答案:Whydoesappend()modifytheprovidedslice?(Seeexample)(1个回答)关闭4年前。我试图在一个函数内向我的slice添加一个元素。我可以更改slice的元素,但不能向其添加新元素。既然slice就像引用一样,为什么我不能更改它?下面是我试过的代码:packagemainimport("fmt")funcmain(){a:=[]int{1,2,3}change(a)fmt.Println(a)}funcchange(a[]int){a[0]=4a=append(a,5)}

函数返回后不改变指针

语言是“Go”(“Golang”)。函数initApp正在接收指向对象的指针(Go中的“struct”)。在函数内部,我创建了一个新的对象指针并初始化了对象的值。打印和调试器都表明在函数返回之前一切都很好。但是在Return之后,作为函数参数的指针具有与函数调用之前相同的空值。为什么会这样?代码在这里:https://pastebin.com/0Gww2CQC//ptr.go.packagemainimport"fmt"typeClassXstruct{NamestringAgeint}funcmain(){varobj*ClassXinitApp(obj)fmt.Println(ob

转到高阶函数

我想了解Go中的高阶函数。我有以下程序:packagemainimport"fmt"funccaller(foofunc(string)string){result:=foo("David")fmt.Println(result)}bar:=func(namestring)string{return"Hello"+name}funcmain(){caller(bar)}当我运行它时:gorunhigher_order_functions.go它给出了以下错误:#command-line-arguments./higher_order_functions.go:10:1:syntaxer