golang 的 go异步编程通道要注意的问题
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个通道加锁 然后接受了 才解锁 这样才能保证队列
如果遇到什么不懂的地方直接关注公众号留言(本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须在文章页面给出原文连接,否则保留追究法律责任的权利。)
作者:newmiracle
出处:https://www.cnblogs.com/newmiracle/

浙公网安备 33010602011771号