博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Go中运用chan的简单案例
阅读量:6941 次
发布时间:2019-06-27

本文共 717 字,大约阅读时间需要 2 分钟。

hot3.png

开发环境:windows7 64位、编辑器:sublime text3

简要说明:Go中可以创建有缓冲的chan(比如:  c1:=make(chan int,4)就是缓冲区大小为4的chan了 ),也可以创建没有缓冲的chan(比如: c2:=make(chan int)就是没有缓冲的chan)。

代码如下,代码中有注释:

package main

import (
"fmt"
)
func main() {
c := make(chan int, 2) //创建带有缓冲的chanel,缓冲大小是2
//这样调用函数,那么f1和f2就是并发执行了
go f1(c) //将参数c传递给f1()
go f2(c) //将参数c传递给f2()
c1 := <-c
c2 := <-c //main函数只有从c中接收到俩个值,才会退出main(),否则main()中会阻塞这那直到c中有数据可以接收
fmt.Printf("c1:%d   c2:%d", c1, c2)
}
func f1(c chan int) { // chan int 表示参数的类型是存储int类型的chanel
c <- 1 //向这个chanel中传入1,之后main()中就会接受到1
}
func f2(c chan int) { // chan int 表示参数的类型是存储int类型的chanel
c <- 2 //向这个chanel中传入2,之后main()中就会接收到2
}

运行结果如图所示(结果显示c1的值是2而不是1,c2的值是1而不是2):

转载于:https://my.oschina.net/u/2518341/blog/530182

你可能感兴趣的文章
Linux如何统计进程的CPU利用率
查看>>
世界那么大,要不来看看?
查看>>
用递归方法对二叉树进行层次遍历
查看>>
Git分支管理策略
查看>>
mysql三范式
查看>>
hdu2048
查看>>
第一次写简历
查看>>
linux/centos/redhat 安装mono环境 X64系统
查看>>
Servlet,Filter,Listener,Interceptor的作用和区别
查看>>
学习 Message(4): 通过 Application.OnMessage 或 TApplicationEvents 响应消息
查看>>
HTML 学习 form 表单操作
查看>>
注册51cto博客的第一天
查看>>
CSS字体样式的缩写
查看>>
linux视频教程之vsftp_A
查看>>
LAMP平台部署及应用
查看>>
查看服务器RAID卡信息的SHELL脚本和命令介绍
查看>>
javascript基础函数
查看>>
Windows平台分布式架构实践 - 负载均衡
查看>>
MongoDB结合PHP
查看>>
ZABBIX微信报警
查看>>