草庐IT

goroutines

全部标签

Goroutine 在 Windows 和 Linux 上的行为不同

我是GO的新手。我有以下遗留代码。vardb*sql.DBfuncinit(){gofeedChan()connString:=os.Getenv("DB_CONN")varerrerrordb,err=sql.Open("postgres",connString)iferr!=nil{log.Fatalf("Failedtoconnecttodatabaseat%q:%q\n",connString,err)}//confirmconnectioniferr=db.Ping();err!=nil{log.Fatalf("Unabletopingdatabaseat%q:%q\n",c

go - 找出谁启动了 goroutine (pprof)

在检查pprof的输出时,我可以看到goroutine的堆栈跟踪。但是我想知道是谁开始(产生?)这个goroutine,这可能吗? 最佳答案 如果您查看端点/debug/pprof/goroutine?debug=2,您会得到堆栈跟踪的稍微不同的输出:goroutine859579[running]:runtime/pprof.writeGoroutineStacks(0x176a0e0,0xc43403a340,0x178d740,0x30)/usr/local/go/src/runtime/pprof/pprof.go:585+

跨并行 goroutine 共享 channel 时的 Golang 竞争条件

我正在编写此示例代码来自学如何跨并行goroutine共享channel,但我遇到了竞争条件。该程序应该启动与系统上可用的CPU一样多的goroutine。第一个访问blchannel的goroutine立即将channel设置为包含false,这样就没有其他goroutine可以访问范围超过stchannel的循环。其他goroutine应该在第一个访问blchannel的goroutine从stchannel读取并打印每个值时结束。packagemainimport("fmt""runtime""strconv""math/rand""time""sync")funcmain(){

go - 为什么这个 goroutine 会阻塞?

这个goroutineblock...golog.Fatal(http.ListenAndServe(":8000",nil))log.Print("Thisdoesn'tprint")这个goroutine不会阻塞...gofunc(){log.Fatal(http.ListenAndServe(":8000",nil))}()log.Print("Thisprints")这个goroutine也不会阻塞...gohttp.ListenAndServe(":8000",nil)log.Print("Thisprints") 最佳答案

go - 我们是否应该为每个异步请求运行一个 goroutine,即使它们是相互产生的?

我正在用go开发一个web应用程序,我知道在http包中,每个请求都在一个单独的goroutine中运行。现在,如果这个goroutine中的代码查询数据库然后等待并使用dbresult调用远程api来获取一些相关数据等等,我应该在单独的goroutine中运行这些调用中的每一个还是http提供的调用是够了吗? 最佳答案 这取决于你在做什么。每个HTTP请求都应该按顺序处理。也就是说,您不应该触发goroutine来处理请求本身:funcmyHandler(whttp.ResponseWriter,r*http.Request){g

goroutines 在打印 timecost 时相互影响

我是Golang的新生。我知道goroutine是一组抽象的cpu和内存来运行一段代码。所以当我在goroutine中运行一些计算函数(比如排序)时,我希望它们并行运行。但是打印的结果看起来很奇怪,“并行”代码打印的时间成本几乎相同。为什么?关于goroutine我是否遗漏了什么,或者是因为funcprintTime()?代码:https://play.golang.org/p/n9DLn57ftM附言应将代码复制到本地go文件并运行。那些在play.golang中运行的有一些限制。结果是:MaxProcs:8Source:2.0001msQuicksort:3.0002msMerge

loops - 将 goroutine 的结果传递给循环内的变量

在下面的代码中,如何将slowExternalFunction的结果分配给适当的person?它可以通过channel完成,为了清楚起见,我定义了slowExternalFunction返回int。typePersonstruct{IdintNamestringWillDieAtint}funcslowExternalAPI(iint)int{time.Sleep(10)willDieAt:=i+2040returnwillDieAt}funcfastInternalFunction(iint)string{time.Sleep(1)returnfmt.Sprintf("Ivan%v"

go - GDB 中 goroutine 的展开堆栈,用于 golang exe 的核心转储

我需要分析一些用Golang编写的服务器的核心转储文件。但我无法使用GDB展开堆栈信息(甚至一点点有用的信息)。比如我有一个main.go,它的代码是:packagemainfuncmain(){panic("stupid")}然后我使用以下方法获取核心文件:ulimit-cunlimitedGOTRACEBACK=crash./main然后我运行gdbmaincore。在gdb中,如下所示。xxx@ubuntu:/tmp/crash$gdbmaincoreGNUgdb(Ubuntu7.12.50.20170314-0ubuntu1.1)7.12.50.20170314-gitCopy

go - 一个 ticker 是否通过它的 ticker.C 告诉一个 goroutine 它被停止了?

packagemainimport"fmt"import"time"funcmain(){ticker:=time.NewTicker(time.Millisecond*500)gofunc(){fort:=rangeticker.C{fmt.Println("Tickat",t)}fmt.Println("tickerstopped")}()time.Sleep(time.Second*5)ticker.Stop()time.Sleep(time.Second*5)}我想当我调用ticker.Stop()时,ticker.C应该告诉goroutine它结束了,所以for循环应该结束,

go - 事情发生的顺序是什么?

我通过浏览官方网站上的围棋之旅开始接触围棋。我只有基本的编程经验,但在进入channel页面时,我开始四处游玩,试图了解它,结果我感到很困惑。这就是我的代码:packagemainimport"fmt"funcsum(s[]int,cchanint){sum:=0s[0]=8s=append(s,20)fmt.Println(s)for_,v:=ranges{sum+=v}c这是我得到的结果:7[8282040][82820][84020]263258[828840]我知道在创建一个slice时你会得到一个底层数组,下面有所需的数字,并将一个slice传递给一个函数并修改一个修改底层数