草庐IT

GoLang 在运行时强制计算,而不是编译时

我正在做一个项目,该项目应该有64位或32位版本。由于第3方驱动程序,我被迫使用int,而不是int64。const(_=iota//ignorezeroiotaKiB=1不幸的是编译器报错,我得到一个constant5368709120overflowsint错误。我怎样才能有效地解决这个问题?有什么方法可以强制在运行时进行这个5*GiB计算? 最佳答案 只需将变量显式键入int64而不是平台相关的int:varThirdPartyDriverBytesint64const(_int64=iota//ignorezeroiotaK

google-app-engine - 如何使用 Go 运行时在 App Engine 上的实例之间传递套接字?

Python运行时通过picklingtheconnection允许它.是否有类似的方式在经典AppEngine上使用Go运行时与google.golang.org/appengine/socket共享套接字? 最佳答案 描述符未在GoAPI中公开:https://github.com/golang/appengine/blob/master/socket/socket_classic.go#L152typeConnstruct{ctxcontext.Contextdescstringoffsetint64protpb.Create

Golang - 单独运行时长

我有一种算法可以对PNG图像中的像素执行数学运算,然后根据结果绘制新图像。我想显示整个过程的持续时间,然后更具体地显示每个像素所花费的时间。算法的结果显示在终端中:>>imagepixels:921600--widthxheight:960-960>>timeelapsed(m-seconds):165.913052ms我最初的想法是输出elapsed/totalPixels的结果,但是由于类型不正确,这会导致错误。 最佳答案 尝试转换类型elapsed/time.Duration(totalPixels)或int(elapsed)

go - 如何通过运行时获取真实文件名。不同goroutine中匿名函数调用的调用者

我有这个示例代码https://play.golang.org/p/c_2GECIcrW我期望getFileName会打印出类似ma​​in.go:11的内容,但我得到的是asm_amd64p32.s:1014在这种情况下,我该怎么做才能得到预期的结果?我可以存档并继续使用匿名函数吗? 最佳答案 您的期望不正确。为了便于解释,让我在这里粘贴您的代码:packagemainimport("fmt""path/filepath""runtime""time")funcmain(){getFileName(1)time.Sleep(tim

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

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

file - FSNotify 在运行时添加监视目录

我真的不知道如何提出这个问题,但就是这样。我正在使用fsnotify来观察一些目录的变化,当一个文件发生变化时,我将变化同步到另一个目录。但我也想将新创建的目录添加到watch,但它并没有真正起作用。这是我的代码:funcWatcher(){watcher,err:=fsnotify.NewWatcher()deferwatcher.Close()done:=make(chanbool)gofunc(){for{select{caseevent:=函数比较长,但我删除了不重要的部分。一切正常,除了err=watcher.Add(dest)。如何让它观看更多的目录?

golang 运行时包从构建它的系统设置文件路径

我有一个简单的go代码,它使用runtime包如下:packagemainimport("runtime""fmt")funcbar(){pc:=make([]uintptr,1000)n:=runtime.Callers(0,pc)frames:=runtime.CallersFrames(pc[:n])for{frame,more:=frames.Next()if!more{break}fmt.Printf("FILE=%sandFUNC=%s\n",frame.File,frame.Function)}}funcfoo(){bar()}funcmain(){foo()}我已经将G

go - 在启用 pkg/profile 的情况下运行时如何获取示例?

我的主block中有以下内容:funcmain(){deferprofile.Start().Stop()fmt.Println("runningversion",version,"builton",date)fmt.Println()cmd.Execute()time.Sleep(2*time.Second)}其中cmd是一个cobra子命令。我执行gobuild,然后运行二进制文件。我可以看到它生成了一个pprof文件:2018/09/1318:43:26profile:cpuprofilingenabled,/tmp/profile705487093/cpu.pprof...ou

google-app-engine - 具有运行时 go111 url 调度问题的 dev_appserver.py

我仍在努力让我的旧式应用引擎至少在go111下工作(由于依赖于内存缓存,go112将无法工作)。我现在正在为我的静态文件的app.yaml配置问题绊倒,我之前使用了一个完全静态的目录布局,只是在根目录中指定了一些动态处理程序,如下所示:runtime:go111handlers:-url:/_ah/.*script:autologin:adminsecure:always-url:/dynamicscript:autosecure:always-url:/admin/.*script:autologin:adminsecure:always-url:(.*)/static_files:

google-app-engine - GAE 数据存储查看器中的 utf8 错误(Go 运行时)

我正在使用GAE中的Go运行时编写Web应用程序。我正在保存一个包含字符串的结构,它是用MD5对另一个字符串的字节进行哈希处理,然后用十六进制将哈希和字节编码为一个字符串的结果。这是一些代码:foo:="somestring"hashedFoo:=md5.New()hashedFoo.Write([]byte(foo))encodedFoo:=hex.EncodeToString(hashedFoo.Sum())//thisiswhatI'massigningtomystruct,andthensavingintotheDatastore这工作正常,在保存或检索存储的实体(通过代码)时