zoukankan      html  css  js  c++  java
  • 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个通道加锁 然后接受了 才解锁 这样才能保证队列
  • 相关阅读:
    Html
    git和github简易教程
    Java基础
    如何学习一门语言
    leetcode题解(持续更新)
    浅谈安全威胁+引子
    内网渗透基础
    Java运算符
    Java修饰符
    Java变量类型
  • 原文地址:https://www.cnblogs.com/newmiracle/p/12979067.html
Copyright © 2011-2022 走看看