zoukankan      html  css  js  c++  java
  • Go语言的管道Channel用法

    本文实例讲述了Go语言的管道Channel用法。分享给大家供大家参考。具体分析如下:

    channel 是有类型的管道,可以用 channel 操作符 <- 对其发送或者接收值。
    ch <- v // 将 v 送入 channel ch。
    v := <-ch // 从 ch 接收,并且赋值给 v。
    (“箭头”就是数据流的方向。)
    和 map 与 slice 一样,channel 使用前必须创建:
    ch := make(chan int)
    默认情况下,在另一端准备好之前,发送和接收都会阻塞。这使得 goroutine 可以在没有明确的锁或竞态变量的情况下进行同步。

    代码如下:
    package main
    import "fmt"
    func sum(a []int, c chan int) {
        sum := 0
        for _, v := range a {
            sum += v
        }
        c <- sum  // send sum to c
    }
    func main() {
        a := []int{7, 2, 8, -9, 4, 0}
            c := make(chan int)
        go sum(a[:len(a)/2], c)
        go sum(a[len(a)/2:], c)
            x, y := <-c, <-c  // receive from c
        fmt.Println(x, y, x + y)
    }

    希望本文所述对大家的Go语言程序设计有所帮助。

  • 相关阅读:
    url编码
    客户端安全-xss-1类型介绍
    阿里云扩容教程
    jquery获取和设置表单数据
    uMlet建模工具
    phpstorm的调试工具xdebug
    服务器如何处理http请求
    http基础实战
    协程
    Goroutine(协程)为何能处理大并发?
  • 原文地址:https://www.cnblogs.com/bonelee/p/6523549.html
Copyright © 2011-2022 走看看