草庐IT

go - 如何导入导入包的 vendor 包

我正在使用etcd的wal包(https://godoc.org/github.com/coreos/etcd/wal)进行预写日志记录。wal在其vendor包中有go.uber.org/zap。在wal的create函数funcCreate(lg*zap.Logger,dirpathstring,metadata[]byte)(*WAL,error)中,需要传入zap.Logger.我尝试导入go.uber.org/zap,但是当我传入zap.Logger时,go编译器提示“类型不匹配”。packagemainimport("github.com/coreos/etcd/wal")

go - 同步原语原子包

Go中的同步包有Once原语。Do()方法实现了func(o*Once)Do(ffunc()){ifatomic.LoadUint32(&o.done)==1{return}//Slow-path.o.m.Lock()defero.m.Unlock()ifo.done==0{deferatomic.StoreUint32(&o.done,1)f()}}为什么我不能使用此方法的其他版本?func(o*Once)Do(ffunc()){ifo.done==1{return}//Slow-path.o.m.Lock()defero.m.Unlock()ifo.done==0{deferato

go - 在不知道你是否在那个包中的情况下引用 Go 包中的符号?

假设A包中有一个函数F,我正在创建的某些代码需要调用它。怎么调用它?如果我从外部包A调用它,那么我使用A.F(...)并且如果我在A内>我使用F(...)。但是,如果Murphy不让我知道哪个是真的,或者两者都需要字节相同的行怎么办?[注意:我认为这种情况会发生是理所当然的,因为根据我的经验和观察,这通常是一个安全的假设。即使没有技术原因,PHBs和立法者是荒谬的好来源。] 最佳答案 没有这样的语法。观察以下事项:禁止循环导入。这尤其意味着包无法导入自身。因此,包不能使用pkg.S语法引用其符号之一S,因为它将无法导入自身。即使您解

go - 检测导入包中的竞争条件

我有一个包,我在其中编写了一个golang代码。我担心程序运行不正常,因为它会不时输出不同的结果。可能是由于racecondtions。所以我跑了很多次:gorun-racemyprogram但我没有收到任何警告或错误。可能错误出现在我导入的另一个包中。据我了解,-race标志不会检测到它们。如果是这样,我该怎么做(检测不是在我的代码中而是在我导入并在我的代码中使用的包中发生的竞争条件)? 最佳答案 竞争条件检测是假阴性而不是假阳性。这意味着它可以在竞争刚刚发生的任何时候检测到竞争——当一个程序试图同时读取或写入一个共享值时。底线是

go - 在函数中返回结构的值并在另一个包中使用它

我尝试在我的示例项目中创建包配置,但有些东西没有像我预期的那样工作,我有文件夹结构:config/config.go//packageconfigmain.go//packagemain我想在我的主文件中使用配置:funcmain(){conf:=config.GetConf()db:=dbConn{schemas:map[string]*sql.DB{},url:fmt.Sprintf("tcp(%s)",conf.db['dev']),username:db.user,password:db.password,}db.create()}我的配置文件:typeConfigstruct

testing - 在非主程序包中运行类似主程序的程序

我们有一个包含大量复杂测试的包。作为测试套件的一部分,它们在构建等上运行。funcTestFunc(t*testing.T){//lotsofsetupstuffanddefiningsuccessconditionsresult:=SystemModel.Run()}现在,对于其中一个测试,我想介绍某种前端,它可以让我调试一些东西。它不是真正的测试,而是调试工具。为此,我只想运行相同的测试,但使用Builder模式:funcTestFuncWithFrontend(t*testing.T){//lotsofsetupstuffanddefiningsuccessconditionsr

go 测试用例未在主包中运行

这个问题在这里已经有了答案:WhyamIgetting"noteststorun"despitehavingatestfunction?(1个回答)关闭7个月前。我正在尝试编写一个简单的测试以更好地理解golang测试,但测试用例似乎没有执行,我预计它会失败。在我的main.go中我有:packagemainimport"fmt"funcmain(){fmt.Println("run")}functwoSum(nums[]int,targetint)[]int{lookup:=make(map[int]int)fori,n:=rangenums{c:=target-nifj,ok:=l

go - 我无法从 strconv 包访问 err.Err

我可能在这里遗漏了一些非常简单的东西:packagemainimport("fmt""strconv""reflect")funcmain(){s:="abd"fmt.Println(s)_,err:=strconv.Atoi(s)iferr!=nil{fmt.Println(err)}fmt.Println(reflect.TypeOf(err))fmt.Println(err.Err)}我正在尝试提取错误本身,例如ErrSyntax或ErrRange,但我做不到。看完之后:https://golang.org/src/strconv/atoi.go?s=3604:3671#L16我

go - 导入包的正确项目结构

这里的标题是我当前的Go应用程序结构,它提供静态http页面并通过websocket发送数据。在下面的结构中,我有2个包常量和main,但无法使用main包中的常量。Server-ClientGameassetscssindex.cssjsapp.jstemplatesindex.htmlconstantsserver.gogame.gomainmain.gohub.goplayer.go我应该使用Go工作区吗?或者我可以让它按原样工作吗?我的项目目前不在我之前称为“工作区”的GoPathsrc中。 最佳答案 你应该有一个至少包含s

go - go中的包解耦

我们都知道依赖注入(inject)使包解耦。但是我对go中依赖注入(inject)的最佳实践有点困惑。让我们假设包用户需要访问配置包。我们可以将Config对象传递给User方法。这样,只要新代码解析接口(interface),我就可以更改Config包功能。另一种方法是直接调用Config包方法,在这些情况下,只要方法名称保持不变,我也可以更改Config代码。像这样更新:这两种方法有什么不同:packageUserfuncfoo(configConfigObject){config.Foo()}还有这个:packageUserimportConfigfuncfoo(){config