草庐IT

引用计数

全部标签

go - 在 Go 中按值传递还是按引用传递效率更高?

假设我有一个实现如下接口(interface)的结构:typeIFaceinterface{Method1()Method2()Method3()}typeFacestruct{Prop1stringProp2int}//IFaceimplementationhere...现在,如果我有接受IFace的方法,将其设计为接受指向该值接口(interface)的指针是否更好?接受指针:funcDummyMethod(f*IFace){(*f).Method1()}按值:funcDummyMethod(fIFace){f.Method1()}我的第一个猜测是因为这些是结构体,所以按值传递可能

go - 使用 xml.NewDecoder(xmlFile) 在 Go/Golang 中解析大型 XML 文件时如何实现进度计数器?

我按照本网站上的示例编写了一些代码来解析大型XML文件(>3GB):https://blog.singleton.io/posts/2012-06-19-parsing-huge-xml-files-with-go/想法是创建decoder:=xml.NewDecoder(xmlFile),然后用decoder.Token()遍历文件,同时检查所有xml.StartElement。只要找到正确的元素,就会使用decoder.DecodeElement()对其进行解码。一切都很好。我现在喜欢的是一种向用户显示进度的方法。类似于“x%的文件已处理”。我知道如何获取XML的文件大小:Howt

go - 有没有办法使用 atomic.AddUint64 重置计数器递增?

我正在为并发Go应用程序实现全局计数器。我的用例是计数器应在x秒后重置并写入数据库。我试过使用互斥量(我可以使用它来重置计数器)此外,当我增加计数器时,我也会记录一些东西。我发现在应用程序运行大约8-9小时后,记录的行数和计数器值不匹配(互斥版本)计数器值总是更少。我还没有找到造成这种情况的原因。我按以下方式使用互斥量func(s*Metrics)AddQps(){s.qpsMu.Lock()s.qps++s.qpsMu.Unlock()}Andtheflushingofmetricsisdoneasfollows.for{ticker:=time.NewTicker(time.Dur

go - grpc:使用 oneof 会导致无效的内存地址或 nil 指针取消引用

我正在尝试使用Go将proto3结构发送到gRPC服务器。该结构有一个oneof类型,我似乎很好地填充了它。将消息发送到我的gRPC客户端时,我对无效内存地址或nil指针引用感到panic。我有原型(prototype)定义(完整文件位于https://github.com/MovingGauteng/geofancy-rs/blob/master/proto/geofancy.proto:#proto3messageDocument{stringcollection=1;stringid=2;oneofgeo{Pointpoint=4;LineStringline=5;Boundsb

go - 对结构中字段的外部引用是否会阻止该结构被垃圾收集?

例如,如果我有一些typeAstruct{Bstring;Cint},我有一个funcfoo(aA)*string{return&a.B},我用c:=foo(a),a是否必须保留在上下文中,直到c可收集?或者,如果我定义funcfoo1(aA)*string{s:=a.B;return&s这对何时可以收集A有什么影响吗? 最佳答案 在第一个例子中,假设a在调用foo(a)之后没有被使用,a是可收集的,因为你通过了a按值。该函数返回一个指向a副本中的值的指针,因此a变得可收集,但在函数foo中创建的副本不可收集收藏品。现在,如果您将&

reference - 另一种类型中自定义类型的 Golang slice 作为引用

我的Go测试代码出现此错误:$goruntest.go#command-line-arguments./test.go:43:cannotuse&ol1(type*Orderline)astypeOrderlineinarrayelement./test.go:43:cannotuse&ol2(type*Orderline)astypeOrderlineinarrayelement代码packagemainimport("fmt")typeCustomerstruct{Idint64Namestring}typeOrderstruct{Idint64Customer*CustomerO

CSS 文件未被引用

我将此代码作为我的myApp.go:packagefastaticappimport("html/template""log""net/http")funcinit(){http.HandleFunc("/",rootHandler)}funcrootHandler(whttp.ResponseWriter,r*http.Request){http.Handle("/css/",http.StripPrefix("/css/",http.FileServer(http.Dir("css"))))ifr.URL.Path!="/"{errorHandler(w,r,http.Status

pointers - 修复数组替换中引用不正确的 slice

以下go代码无法编译,因为(我相信)指针的引用方式存在错误。特别是,错误信息是prog.go:13:cannotuseappend((*x)[:remove],(*x)[remove+1:]...)(type[]int)astype*[]intinassignment这是导致此错误消息的代码的抽象和简化版本。packagemainimport"fmt"funcmain(){x:=&[]int{11,22,33,44,55,66,77,88,99}fori,addr:=range*x{ifaddr==22{forlen(*x)>5{remove:=(i+1)%len(*x)x=appen

go - 实例化结构和数组不会创建新的引用

我正在尝试将一个简单的markdown文件转换为json,markdown看起来像这样:#TITLE1-Line1-Line2-Line3#TITLE2-Line1-Line2-Line3我无法理解在funcmain()中重构以下内容需要什么:typeSectionstruct{CategorystringLines[]string}file,_:=os.Open("./src/basicmarkdown/basicmarkdown.md")deferfile.Close()rgxRoot,_:=regexp.Compile("^#[^#]")rgxBehaviour,_:=regex

http - Golang,零指针取消引用或无效内存地址

我的代码运行完美,直到我想使用许多并发调用来扩展它。它通过向客户端询问Get请求来工作。这是我得到的:panic:runtimeerror:invalidmemoryaddressornilpointerdereference[signal0xbcode=0x1addr=0x0pc=0x400da9]goroutine125[running]:runtime.panic(0x697480,0x850d13)/usr/lib/go/src/pkg/runtime/panic.c:279+0xf5main.concurrent(0x25e5)/home/maker/go/src/GoBot