所以我明白了,在go中,init()是一个特殊的方法,可以用来初始化一个包中的对象。当我尝试使用此技术时,我收到一个错误,指出该变量已声明但未使用。例如:packagefizzbuzzvarfoostringfuncinit(){foo:="bar"}在我看来,您放入此方法的大部分时间变量不会在int()本地使用,所以这很好。我错过了什么? 最佳答案 这只是在方法中创建了一个名为“foo”的局部变量。您需要通过foo="bar"将字符串分配给模块范围内已声明的var。 关于go-为什么我
我有这样一个函数:varflagvarintfuncinit(){flag.IntVar(&flagvar,"flagname",1234,"helpmessageforflagname")}我想在funcmain()中调用它:funcmain(){init()}但它不起作用,并告诉我init()未定义。有什么问题? 最佳答案 init函数是Golang中的一个特殊函数。它在第一次加载文件时执行,因此您永远不必直接调用它。来自官方文档:Finally,eachsourcefilecandefineitsownniladicinitf
我有一个编译为单个二进制文件的goweb应用程序,我试图通过init.d进行管理。这是我的init.d脚本:PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/binDAEMON=/usr/bin/my-go-appDAEMON_ARGS="--logFile/var/log/my-go-app/my-go-app.log"NAME=my-go-appDESC=my-go-appRUNDIR=/var/run/my-go-appPIDFILE=$RUNDIR/my-go-app.pidtest-x$DAEMON||
我有一个用Golang编写的可执行服务器文件,它由自定义脚本文件运行,位于我的RaspberryPi3B上的/etc/init.d/目录中。服务器启动但不显示我用HTML制作的网站。该网站位于与我的服务器可执行文件相同目录中的“静态”文件夹中。我使用此命令将server.go构建为可执行文件。gobuildserver.go注意如果我通过双击手动启动服务器,网站工作正常(我的服务器显示“static”文件夹)。我的静态文件夹由html、javascript和css文件组成。我认为问题是当我通过脚本启动服务器时,服务器找不到静态文件夹(显示:404页面未找到)。我还希望在RPi启动时启动
我正在开发一个由许多go容器组成的应用程序。我用dockercompose管理它们。最近我一直无法从中获取日志。当我运行“dockerlogs[container-name]”时,我只会看到在init期间为我的应用程序中的包创建的日志,以及在服务开始监听之前的main期间创建的日志。对log.Println或fmt.Println的后续调用不会出现在“dockerlogs”的输出中。你知道会发生什么吗? 最佳答案 您可能想将日志写入/dev/stdout或者简单地使用log.SetOutput(os.Stdout)来自log包裹
我是Go的新手。当运行多个go文件时,包括包、变量和init函数,我卡在了初始化序列中。据我所知,有几个规则:导入的包和init函数应该根据它们出现的顺序被调用。如果A文件导入B文件,B文件导入C文件,则初始化顺序为C->B->A。依赖总是先执行。main包总是最后执行。有一个例子让我很困惑(我被告知初始化顺序是由小数到大数表示的,比如1.1先执行1.2,1.2先执行2.1等等)//p1.gopackagep1import"fmt"//1.1varxfloat32=1.2//1.2funcinit(){//1.3fmt.Printf("p1package,x:%f\n",x)//1.4
在Go中,您可以在给定的包中定义多个init函数,所有这些函数都将在执行之前以未指定的顺序运行。具有多个此类函数的一个后果是无法在正常代码中调用或识别它们。例如,以下将不会编译:funcmain(){fmt.Println(init)}funcinit(){}(参见here的围棋Playground示例)我的问题是-能够拥有多个init函数有什么好处,如果没有多个init函数,我们是否能够引用或调用init函数? 最佳答案 能够拥有多个init函数的优点是IMO主要是它提高了局部的可读性:你可以在被初始化的东西旁边编写初始化函数,而
(编辑以修复大写和添加上下文)在revel的init.go中,我有一个全局变量:DB。packageappimport("database/sql""fmt"_"github.com/go-sql-driver/mysql""github.com/revel/revel")varDB*sql.DBfuncInitDB(){connstring:=fmt.Sprintf("revel:revel@tcp(localhost:3336)/revel")varerrerrorDB,err=sql.Open("mysql",connstring)iferr!=nil{revel.INFO.Pr
在单元测试无法找到的init函数中使用相对路径时,我遇到了一个烦人的问题。假设我有一个结构如下的项目:.├──conf│ └──blacklist├──filter│ ├──filter.go│ └──filter_test.go并且在filter.go的init函数中,我尝试使用相对路径conf/blacklist加载黑名单,避免加载它多次。由于默认工作目录恰好是项目根目录,因此它适用于编译后的二进制文件。然而filter_test.go会panicpanic:openconf/blacklist:nosuchfileordirectory,因为gotest总是使用包目录作为工
我无法在go中对用c编写的实用程序进行docker化和使用。我已经在没有docker的情况下在本地运行了这个程序并且它有效我尝试像这样使用gccgogobuild-compilergccgo-gccgoflags-static-libgo但我得到了同样的错误调用C函数的序言如下所示:/*#cgoamd64x86LDFLAGS:-L.-lsomelib-lsomeotherlib#include#include#include"someheader.h"*/我的docker文件如下所示:FROMgolang:1.12ASbuildWORKDIR/go/src/appCOPY..ENVGO