草庐IT

non-main

全部标签

go - 我应该用 go run 运行服务器吗?或 ./main 有什么区别?

我有一个go服务器,我通常这样运行:开始构建。&&./main但是在网上我看到很多使用gorun的例子。哪个更好用,有什么区别? 最佳答案 来自官方文档(go1.11):gorun-编译并运行指定的主Go包。gobuild-编译由导入路径命名的包,连同它们的依赖项,但它不会安装结果。goinstall-编译并安装由导入路径命名的包。意思是:通常对于LOCAL环境,可以使用gorun,但对于PROD环境,最好使用gobuild构建您的应用并运行./main,但是如果你需要Go工具链,你必须使用goinstall因为它会安装包和依赖项并

go - 语法错误 : non-declaration statement outside function body at fmt. Println(words, length)

我在go之旅中的解释器中有以下内容:packagemainimport"fmt"varsomeString="onetwothreefour"varwords=strings.Fields(someString)varlength=len(words)fmt.Println(words,length)我明白了tmp/sandbox216066597/main.go:11:syntaxerror:non-declarationstatementoutsidefunctionbody我最近通过在任何函数之外使用var而不是:=短语法来更正它,但错误与之前相同。

go - 在子包中引用包 main

刚接触Golang,有一个看似简单的问题。如果我的项目根目录下的主包中有一个记录器(并在logger.go中定义),我该如何在子包中引用该记录器(即:我的routespackage)?我的目录结构是:main.gologger.go路线\routes.go...我认为如果Logger是公开的,它就已经可用于路由,但我在routes.go中得到“undefined:Logger”。如果我尝试在routes.go中导入我的主包,我会收到“不允许导入周期”错误,因为routes.go导入包main和main。go导入包路由。如有任何帮助,我们将不胜感激! 最佳答案

postgresql - 戈朗 : gorm use Find(&model) for non gorm migrate table

有表customer_account(postgres)是从YII2迁移过来的。数据链接:CREATETABLEpublic.test_table(idINTEGERPRIMARYKEYNOTNULLDEFAULTnextval('test_table_id_seq'::regclass),dataJSONB);在go项目中,我尝试从该表中获取值。typeTableGostruct{IdintDatastring`gorm:"type:jsonb"`}table:=TableGo{}db.Where("id=?",75).Find(&table)println(table.Data)但

go - 从另一个文件访问在 main func 中创建的运行时配置实例

我有一个应用程序其他部分需要的运行时配置实例,但它只能在main()中创建。理想情况下,我想避免使用全局变量。//main.gotypeRuntimeConfigstruct{db*DatabaseInstanceapp_namestring...etc...}funcmain(){dbInstance=ConnectToDB(...args)//returns*DatabaseInstanceruntimeConfig:=*Config{dbInstance,"Myapp",...etc...}}//elsewhere.gofuncSomeUtilityFuncThatNeedsRu

go - 如何使 func main() 中设置的数据库实例对其他包可用?

我正在编写我的第一个goweb应用程序,我有以下结构:.├──main.go├──model│├──model.go│└──book.go├──route│└──route.go└──view└──view.go/main.go是我的ma​​in()所在的位置。在该文件中,我还定义了一个变量Env,我将在其中保存我的数据库实例(至少这是计划)。在/main.go我做import"project/view"typeEnvstruct{dbmodels.Collection}//restofthecodefuncmain(){db,err:=models.NewDB()//etcMyEnv

c - 如何在没有定义 main() 的情况下让 cgo 构建目标文件?

我有一个完全用C编写的项目。我只需要调用一个必须用GO编写的函数。因此,我使用cgo构建C文件,然后我想使用生成的目标文件与我的主C项目链接。假设我有一个文件foo.go和一个函数funcHelloWorld()。我希望从我的C代码中执行此函数。所以我做了以下步骤#gotoolcgofoo.go#cd_obj&&gcc-c*.o现在我有两个文件:#_cgo_export.o_cgo_main.o但是,main()以某种方式在那里定义,我无法将这些目标文件与我的主项目(多个主项目)链接。我如何让cgo不放入虚拟main?还是我这样做完全错了?编辑我需要入口点在C中。其他人发布的建议要求入

go - IB API下单错误: cannot set VOL attribute on non-vol order

我正在尝试使用aGoportibAPI连接到我的InteractiveBrokersTrader工作站。我可以连接API并从中读取数据,但是当我尝试在模拟交易账户上下订单时,出现以下错误:&{1321Errorvalidatingrequest:-'bB':cause-CannotsetVOLattributeonnon-VOLorder.}但我不相信我在请求中设置了VOL属性。重现错误的最小程序是:packagemainimport("fmt""math""time""github.com/gofinance/ib")funcmain(){eng,err:=ib.NewEngine(

go - 如何将本地目录中的包包含到 main.go 中

我在windows10中使用go版本go1.11.2windows/amd64我在桌面上有一个名为“GoPro”的文件夹,其中有一个文件-main.go一个文件夹-模块“模块”文件夹包含一个文件-Modules.go文件夹结构Desktop|------->GoPro|----->main.go|----->Models|---->Models.go主.go//desktop/GoPro/main.gopackagemainimport("./Models")funcmain(){Models.Printhello()}模型.go//desktop/GoPro/Modelspackag

sql-server - sql : Scan error on column index 0, name "": unsupported Scan, 将 driver.Value 类型 int64 存储到类型 *main.SMSBlast 中?

我现在正在尝试restfulapi,其中列SequenceID不是自动增量,因为故意的,当我像这样计数时,我的问题是库gormcountSequenceId:=db.Debug().Table("SMSBlast2").Count(&smsblast1),结果是sql:列索引0上的扫描错误,名称“”:不支持的扫描,将driver.Value类型int64存储到类型*main.SMSBlastpackagemainimport("encoding/json""fmt""github.com/gorilla/mux""github.com/jinzhu/gorm"_"github.com/