记一次Goland中go func协程使用问题

背景:多地服务需要数据同步,服务内部起了一个协程去调用同步服务,测试妹子将多地服务场景变为一地服务,同步时相当于一个服务在自循环。

1.服务请求为http请求,用的库为fasthttp,错误示例代码

协程使用方式为go func() {} ()方式,请求过程中发现ctx.Request.Body()信息会丢失。

思考无果.......

2.go 中协程的使用有两种方式,一是 go + 方法,二是go func() {} (),第二种方式有问题时换用了第一种发现结果正常,可以正常访问。

3.此时感觉是因为go func() {} ()中参数引用问题,查询资料后发现这样一篇文章

看完之后将代码修改为如下

但是结果还是不对,body内容仍然会丢失!!!

4.无果之后有看了下代码,突然觉得参数是不是不能用 fasthttp.RequestCtx ?然后在协程外将body取出,改为如下

然后再次请求就可以了,嗯,可以了。。。

5.感觉上下文信息不能直接在协程中引用,更深层次原因待探索.....各位手下留情~

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,关于golang协程池,我可以给您一些解释和建议。 首先,协程池可以提高程序的效率,减少创建和销毁协程的开销。在golang,可以使用sync包的WaitGroup和Pool来实现协程池的功能。 WaitGroup可以用来等待一组协程的执行完成,而Pool可以用来管理协程的数量和复用协程。 下面是一个简单的示例代码: ``` package main import ( "fmt" "sync" ) func worker(id int, jobs <-chan int, results chan<- int) { for j := range jobs { fmt.Println("worker", id, "started job", j) fib := Fibonacci(j) fmt.Println("worker", id, "finished job", j) results <- fib } } func Fibonacci(n int) int { if n <= 1 { return n } return Fibonacci(n-1) + Fibonacci(n-2) } func main() { const numJobs = 10 jobs := make(chan int, numJobs) results := make(chan int, numJobs) // 创建协程池并启动10个协程 var wg sync.WaitGroup for w := 1; w <= 10; w++ { wg.Add(1) go func(id int) { defer wg.Done() worker(id, jobs, results) }(w) } // 发送10个任务到协程池 for j := 1; j <= numJobs; j++ { jobs <- j } close(jobs) // 等待所有任务完成并关闭结果通道 wg.Wait() close(results) // 输出结果 for r := range results { fmt.Println("result:", r) } } ``` 在这个示例,我们创建了一个有10个协程协程池,并将10个任务发送到任务通道。每个协程会从通道取出任务,执行任务,然后将结果发送到结果通道。最后,我们等待所有任务完成,关闭结果通道,并输出结果。 希望这个示例代码可以对您有所帮助。如果您有任何其他问题,请随时问我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值