• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

golang的go异步编程通道要注意的问题

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

golang 的 go异步编程通道要注意的问题

import (
	"database/sql"
	"fmt"
	"github.com/gin-gonic/gin"
	_ "github.com/go-sql-driver/mysql"
	"log"
	"time"
)

var Db *sql.DB


func main() {


	c1 := make(chan string)


	r := gin.Default()
	r.GET("/ping", func(c *gin.Context) {


		go say("wfe", c1)
		y := <-c1// 从通道 c 中接收


		c.JSON(200, gin.H{
			"message": y,
		})

	
	})
	
	r.Run(":8082") // listen and serve on 0.0.0.0:8080
}

  用了 

y := <-c1// 从通道 c 中接收
就会堵塞线程监听 这个有点像消息队列 直到接受完毕
如果你不想堵塞 直接用go 函数调用就行

一般不用他做消息队列 cpu使用率上不去 并发量也低
所以go的通道一般情况下还是不要用了 毕竟并发量处理不好 因为他都要加锁 进入1个通道加锁 然后接受了 才解锁 这样才能保证队列

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
[Go]gomod下载的依赖包位置发布时间:2022-07-10
下一篇:
3.2goWaitGroup代码示例发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap