草庐IT

built-in-types

全部标签

performance - 戈朗 : right way to store map structure in lru cache

我有一个像这样的结构:map[key]value,我想通过一个字符串将它存储在"github.com/golang/groupcache/lru"中键,例如cacheKey。这是我的问题:我发现每当我想更新缓存项时,我都需要先获取:item:=cache.Get(cacheKey)ifv,ok:=item[key];ok{item[key]=new_valuecache.Add(cacheKey,item)}这样做是否正确?或者,正如一些人所建议的,我需要重新设计我的结构,以确保我可以在任何时候更新它时执行cache.Add(cacheKey,item)。或者,我什至应该使用像cach

golang 操作系统/exec : get data from stdout in parts

我想使用os/exec从我的go代码运行一个外部应用程序。应用程序my_external_script.sh分两部分将数据输出到stdout:第一部分非常快(三秒后将“A”写入stdout),第二部分("B)仅在10秒后写入。例如:./my_external_script.sh..........A(3secondselapsed)..............................B(10secondselapsed)(programexitswith0statuscode)我目前正在从我的go代码中这样执行:funcexecMyExternalCmd()(*string,e

戈朗 : building interfaces for existing types to make code testable

为了使调用sql包的代码可测试,我构建了以下2个接口(interface):typeDatabaseinterface{Close()errorQuery(string,...interface{})(DatabaseRows,error)}typeDatabaseRowsinterface{Close()errorNext()boolScan(...interface{})error}我要测试的实际代码是:funcgetDatabase(connectionStringstring)(dbDatabase,errerror){ifdb,err=sql.Open("mysql",con

go - 为什么 golang duck typing 在我下面的代码中对我不起作用?

在下面的代码中,我尝试创建模型接口(interface)和API接口(interface)的具体实现:packagemainimport"fmt"/////////typeModelinterface{ID()string}typeAPIinterface{Create(Model)}/////////typeConcreteModelstruct{}func(modelConcreteModel)ID()string{return"123"}func(modelConcreteModel)Name()string{return"aron"}typeConcreteAPIstruct{

postgresql - 带有长列表的 Sqlx WHERE IN 查询

我正在使用sqlx在我的Go代码中执行查询。该查询有一长串值(~10,000),我需要在WHEREIN(?)子句中对其进行过滤。这会导致性能大幅下降。我该如何优化这样的查询?此外,此查询是在Redshift集群上执行的,因此索引列不是提高查询性能的解决方案。values:=[]int64{143,123,123,542....}//~10,000elementsquery,args,err:=sqlx.In(query,values)iferr!=nil{returnnil,err}query=dbInterface.Rebind(query)err=dbInterface.Selec

regex - 去正则表达式 : how I can replace named groups by concrete values in source pattern?

也许,你可以帮我。例如,我有像(?P\w+)(?P\w+)这样的正则表达式.我如何使用map[string]string{"name":"Alice","surname":"Cool"}替换组以获得字符串AliceCool?这可能吗?谢谢。 最佳答案 好的,我找到了制作方法。希望它会对某人有所帮助。https://play.golang.org/p/Xz9PtE_bIt 关于regex-去正则表达式:howIcanreplacenamedgroupsbyconcretevaluesins

Golang unix 套接字 : registering same type for RPC on different sockets?

我在Go中工作,对使用unix套接字有点陌生。尝试搜索类似的问题,但找不到任何内容,如果之前已经回答过,我们深表歉意。我想用unixsockets模拟一个机器集群进行测试。我正在测试我的Raft实现,所以我想在不同的unix套接字上注册相同类型的多个对象(一个庞大的结构)。但是看我写的一个简单的例子,效果似乎不是我想要的:为同一个导出方法拨不同的套接字似乎在单个端口上崩溃:packagemainimport("net""fmt""net/rpc""log""sync")typeServerstruct{namestring}typeSpeakArgsstruct{}typeSpeakR

linux - 最小起订量 : running "moq": exec: "moq": executable file not found in $PATH

在尝试moq框架的示例时,当我输入“gogenerate”时出现以下异常:example.go:5:running"moq":exec:"moq":executablefilenotfoundin$PATH我该怎么办?我正在使用Kubuntu16.04PS:我试过了exportPATH=$PATH:/home/[...]/go/src/github.com/matryer/moq没有成功 最佳答案 @sprabhakaran得到了正确的答案。我只需要将go二进制文件夹添加到PATH全局变量:exportPATH=$PATH:/hom

mysql - golang mysql DESCRIBE表导致driver.Value type nil错误

我第一次尝试使用golang查询MySQL数据库,但是当我运行命令gorunmain.go时出现以下错误。2017/10/2221:06:58sql:Scanerroroncolumnindex4:unsupportedScan,storingdriver.Valuetypeintotype*stringexitstatus1这是我的main.go主.gopackagemainimport("log""database/sql")import_"github.com/go-sql-driver/mysql"vardb*sql.DBvarerrerror//mainfunctiontob

api - 伊姆古尔 API : POST comment in GO

我正在尝试通过ImgurAPI向imgur发表评论。但我无法使有效载荷正确。我已经查看了Imgur的关于此的页面,他们表明应该像我在strings.NewReader中那样对其进行编码。图片ID为nP0uKKOfuncHandleComment(whttp.ResponseWriter,r*http.Request){parts:=strings.Split(r.URL.Path,"/")switchr.Method{case"POST"://URLforPOSTingcommenturl:="https://api.imgur.com/3/comment"//Authorizatio