草庐IT

java - 为什么用 Golang 写的一些函数运行起来比用 Java 还要慢?

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭3年前。Improvethisquestion我用Golang和Java测试了几个简单的函数。令我惊讶的是,Java有时比Golang更快(尤其是在递归函数和标准库中的某些函数,如math/rand.Rand)。我想知道为什么。这是我用于测试的一些代码和结果。Golang代码:packagemainimport("fmt""math/rand""time")funccalPi(pointCountint)float64{inCircleCou

performance - Golang goroutine 在添加并发时变慢

我正在研究golang和goroutine的使用。使用此示例代码,在我具有4个逻辑CPU的PC上,我无法理解为什么我没有任何性能提升。如果我添加并发,那么它所花费的时间往往会比没有并发的原始时间慢。2017/10/2713:57:17Starting1threads2017/10/2713:57:27Idroutine:0rate:232.5581402017/10/2713:57:27Currenttotalratewas232.56K/s2017/10/2713:57:27Starting1threads2017/10/2713:57:37Idroutine:0rate:357.1

go - Go sync.pool 比 make 慢很多吗?

我尝试使用sync.Pool来重用[]byte。但事实证明它比make慢。代码:packagemainimport("sync""testing")funcBenchmarkMakeStack(b*testing.B){forN:=0;N结果:$gotestpool_test.go-bench=.-benchmemBenchmarkMakeStack-420000000000.29ns/op0B/op0allocs/opBenchmarkBytePool-410000000017.2ns/op0B/op0allocs/op根据Go文档,sync.Pool应该更快,但我的测试显示并非如此

go - 在生产者速度慢,消费者速度快的情况下,如何处理 channel 关闭同步?

关闭。这个问题是opinion-based.它目前不接受答案。想改善这个问题吗?更新问题,以便可以通过editingthispost用事实和引文回答问题.3年前关闭。Improvethisquestion我是新手,找不到这个问题的答案。我正在做的是在生产者中读取CSV文件,做一些可能需要时间的事情,然后通过channel将输出发送给消费者。有一连串生产者-消费者s,并且任何生产者最终都可能比它的消费者慢。producer(1goroutine)->chan0->consumer-producer-1(>1goroutines)->chan1->consumer-producer-2(>

go - 编译二进制比运行慢 "go run"

我正在尝试解决代码谜题的出现(所以对于那些还没有完成第一天的人来说剧透警告),我遇到了一些我无法理解的事情。我有一个函数,它根据其他一些数字列表生成一个数字列表,并返回第二次遇到的第一个数字:funcfindFirstDoubleFrequency(freqs[]int)int{seen:=map[int]bool{0:true}freq:=0for{for_,f:=rangefreqs{freq+=fifseen[freq]==true{returnfreq}seen[freq]=true}}}当我使用gorun运行我的代码时,函数需要约15毫秒才能完成。但是,当我使用gobuild

sql - Golang sql 包查询比 PostgreSQL SQL 查询慢

我正在使用GolangSQL包来调用我的数据库。我正在使用准备好的语句,并且在列上有索引stmtHas:=db.Prepare(`SELECTvalueFROM`+tableName+`WHEREkey=$1;`)now:=time.Now()err:=db.stmtGet.QueryRow(key).Scan(&value)elapsed:=time.Since(now)fmt.Println(elapsed)这会打印-40.874782ms然而,与此相比,原始SQL查询花费的时间要少得多。EXPLAIN(ANALYZE,BUFFERS)SELECTvalueFROMtableNam

performance - 为什么 "MOVQ 0x30(SP), DX"慢?

请看下面的pprofsession。在treesort.add的第42行中,有一个int比较。我认为它占所有cpu时间的64%。在disasm中,操作是“MOVQ0x30(SP),DX”。为什么这么慢?File:treesort_bench.test.exeType:cpuTime:Sep7,2018at3:15pm(EDT)Duration:2.60s,Totalsamples=2.43s(93.44%)Enteringinteractivemode(type"help"forcommands,"o"foroptions)(pprof)top10Showingnodesaccount

database - Golang 代码的运行速度真的比 PHP 中的相同代码慢

Golang新手,昨天我开始使用Golang并编写了一些实际用PHP编写的代码。我只是想看看性能上的差异。我在PHP中做完全相同的事情,响应在http请求中完全相同,但Golang的执行速度非常慢,即使在编译之后也是如此。我试图了解我在Golang中使用的哪些东西不应该使用,以及我如何才能提高这段代码的性能。我知道遍历映射很慢,但是PHP使用散列映射来实现多维数组。我可以保证我使用的sql查询是从PHP粘贴的完全相同的副本,机器相同,并且两个代码中的循环数相同。packagemainimport("database/sql""encoding/json""fmt"_"github.co

postgresql - 从查询到 c.JSON 非常慢

我正在使用Gorm查询我的数据库,然后使用gin的c.JSON将结构编码为json。这是一个大型查询,结果不多(我不知道从哪里开始解决这个问题。[2019-07-0214:41:04][946.63ms]SELECTbigslowquery[62861rowsaffectedorreturned][GIN]2019/07/02-14:41:11|200|7.92347114s|ip|GET/api/date/2019-05-30[2019-07-0214:40:44][660.47ms]SELECTbigslowquery[7583rowsaffectedorreturned][GIN

assembly - 为什么汇编 POPCNTQ 基准测试会比使用整数技巧的 native Go 函数慢?

ASM版本TEXT·CountBitsUint64PopCnt(SB),NOSPLIT,$0POPCNTQx+0(FP),AXMOVQAX,ret+8(FP)RETGo版本const(m1quint64=0x5555555555555555m2q=0x3333333333333333m4q=0x0f0f0f0f0f0f0f0fhq=0x0101010101010101)funcCountBitsUint64(xuint64)int{x-=(x>>1)&m1q//putcountofeach2bitsintothose2bitsx=(x&m2q)+((x>>2)&m2q)//putcou