草庐IT

CALL_NON_FUNCTION_AS_CONSTRUCTOR

全部标签

function - 试图将在程序 1 中创建的类型 ("object") 传递给程序 2 中的函数

我在python上花了很多时间,现在正在尝试学习golang。我正在尝试用golang做一些我经常用python做的事情;本质上是在一个程序中创建一个对象,然后将该对象传递给另一个程序中的方法(或函数)。我知道golang没有对象,但我也认为我不应该定义一个已经定义过的类型。我的示例代码如下:程序1:import("github.com/bndr/gojenkins""bitbucket.org/elsammons/senjink/actions")funcmain(){jenkins:=gojenkins.CreateJenkins(url)_,err:=jenkins.Init()

go - rpc Call 方法是否在与服务器相同的 go routine 中运行?

我的服务器:func(t*Arith)Multiply(args*Args,reply*int)error{*reply=args.A*args.Breturnnil}funcmain(){arith:=new(Arith)rpc.Register(arith)rpc.HandleHTTP()l,e:=net.Listen("tcp",":1234")ife!=nil{log.Fatal("listenerror:",e)}gohttp.Serve(l,nil)}客户:client.Call("Arith.Multiply",args,&reply)我认为Multiply在另一个gor

function - 将变量 []interface{} 转换为变量 ...interface{} in go

我正在使用gomysql库来执行多个数据库任务。鉴于我想在mysql库上编写一个包装器包,我发现自己陷入了以下情况:我有一个具有以下签名的方法:func(db*MySQL)Insert(querystring,args...interface{})(int64,错误)此方法从具有以下签名的库中调用db.Exec函数:func(db*DB)Exec(querystring,args...interface{})(Result,error)似乎当我调用我的方法时Insert("somequery",1,"test")values...interface{}被翻译成[]interface{}

function - 如何从 Go/Golang 中的另一个方法表达式访问方法表达式(结构函数)?

我正在尝试清理我的Go/Golang项目中的代码。我认为以面向对象的方式创建模型可能是惯用的,这样我就可以做到,例如:db.Users.GetID("john")(在“users”表中做一件事)db.Purchases.GetTotal()(在“purchasaes”表中做一件事)等等。但是,这样做的一个问题是数据库函数无法在需要时自行调用。这是我正在谈论的一个小的、人为的例子:packagemainimport"fmt"//AmodelthatcontainsallofthestructsforourdatabasetablestypeModelstruct{UsersPurchas

function - 缺少函数体

这个问题在这里已经有了答案:BodilessfunctioninGolang(2个答案)关闭5年前。当我在Golang中看到math.Sin时,我很纳闷,因为它是两个同名的函数,但第一个函数没有函数体。见下文:例如math.Acos://Acosreturnsthearccosine,inradians,ofx.////Specialcaseis://Acos(x)=NaNifx1funcAcos(xfloat64)float64funcacos(xfloat64)float64{returnPi/2-Asin(x)}但是当我想用下面的语句创建一个非常非常简单的uuid包时:packa

go - 函数值 ('function pointers' ) 在 Go 中究竟是如何实现的?

来自thedocumentationforreflect.Value.Pointer():Ifv'sKindisFunc,thereturnedpointerisanunderlyingcodepointer,butnotnecessarilyenoughtoidentifyasinglefunctionuniquely.TheonlyguaranteeisthattheresultiszeroifandonlyifvisanilfuncValue.很明显,函数值变量必须包含的不仅仅是代码指针。鉴于Go支持方法指针,这不足为奇-但实际的底层实现是什么?(对于使用反射创建的函数值,它有何

go - panic : runtime error: slice bounds out of range when concurrently running as goroutine

我将一个函数作为goroutine调用,并使用WaitGroup来防止在它们全部完成之前关闭共享扫描仪。myfunc()函数迭代一个文件。我想内存映射这个文件并在所有goroutine之间共享它,而不是每次都从磁盘读取I/O瓶颈。有人告诉我这种方法可行inananswertoanotherquestion.然而,虽然这个函数独立运行良好,但它不能同时运行。我收到错误:panic:runtimeerror:sliceboundsoutofrange但错误是当我调用Scan()方法时(不在slice上),这令人困惑。这是一个MWE://...packagedeclaration;impor

去反射 panic : Call using interface{} as type

我在修改Go中的反射时遇到了一个有趣的场景。call1()有效(返回“hello!”),而call2()因reflect:Callusinginterface{}astype而出现panic字符串.在下面的代码中,call1()和call2()之间的唯一区别是如何创建和初始化inValue。我可以清楚地看到为什么call1()导致inValue成为一个string,而call2()导致inValue成为一个interface,所以我的问题不是为什么我的代码会产生这个,而是:为什么Go在第二种情况下不能执行函数调用?我认为接口(interface)仍然包含成功调用该方法的所有必要信息,因

unit-testing - 如何编写When a function having the parameters of c *gin.Context 的测试用例

我正在用golang为我的项目编写Controller的测试用例。在Controller中有函数名称SaveProvider()有参数c*gin.Context我不知道如何将JSON传递给c*gin.Context这个参数以及我如何测试我在Controller中使用的函数谁能告诉我这段代码中的问题是什么。它也称为表驱动测试。packagecontrollersimport("bkapiv1/models""fmt""testing""github.com/gin-gonic/gin")funcTestSaveProvider(t*testing.T){typeargsstruct{c*

postgresql - 如何从 Go 中的 Cloud Function 连接到 Cloud-SQL?

对于一个项目,我正在尝试将云功能连接到云sql数据库设置,如thisquickstartguide中所述。.该功能配置在同一区域,服务帐户具有角色CloudSQL-Client。我通过我的计算机调用函数是这样的:gcloudfunctionscall--region=--data'{"recipient":"hello","requester":"hello","message":"test"}'与函数的连接正常,似乎只是对数据库的身份验证不起作用,但我不知道我失败的地方。我多次检查了密码、用户和连接名,重设了密码,还是不行。我发现了问题here与将云功能连接到云sql相关。我尝试用单