Golang语言--- channel
时间:2022-05-05
本文章向大家介绍Golang语言--- channel,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
// xuhh_go_channel project main.go
/*
channel
1. channel 在读取数据的时候,如果此时通道内没有数据,则会阻塞。
在取数据的时候,如果此时通道内没有数据,则也会阻塞。
2. channel 在创建的时候会存在一个数据缓冲,如果通道内存入的数据超过缓冲,则就会崩溃。
range 在遍历 channel 的时候需要注意的问题:
1. range在遍历channel的时候,一直在运行,直到close(channel)的时候才会结束调用。
2. range会一直读取数据,如果没有数据,就会阻塞在那里。
len(channel):channel内未被读取的len
cal(channel):channel的容量
select机制 :
1. 检查每个case语句
2. 如果有任何一个channel 是send 或者是 recvive的,那么就执行该block
3. 如果多个case都是ready的情况下,随机选择一个case执行。
4. 如果所有的case都没有ready的,此时如果有default语句的,则执行default,没有的话则阻塞并等待。
*/package main
import (
"fmt"
"runtime"
"time"
)
func main() {
chan1 := make(chan int)
exit := make(chan bool)
go func() {
for {
nTemp := <-chan1
fmt.Println(nTemp)
if nTemp == 4 {
exit <- true
break
}
}
}()
chan1 <- 1
chan1 <- 2
chan1 <- 3
chan1 <- 4
var bRet bool = <-exit
fmt.Println(bRet)
close(chan1)
chanRan := make(chan int, 4)
go func() {
for v := range chanRan {
fmt.Println(v)
}
exit <- true
}()
chanRan <- 5
chanRan <- 6
chanRan <- 7
chanRan <- 8
close(chanRan)
bRet = <-exit
chanTimeOut := make(chan bool, 1)
chanTest := make(chan int, 1)
fmt.Println("下面是测试select相对于channel的用法 以及利用 select 来设置超时:")
go func() {
for i := 0; i < 3; i++ {
time.Sleep(1e9)
chanTimeOut <- true
}
}()
for i := 0; i < 3; i++ {
select {
case chanTest <- i:
fmt.Println("success write %d to channel", i)
case chanTest <- i + 1:
fmt.Println("success write %d to channel", i+1)
case chanTest <- i + 2:
fmt.Println("success write %d to channel", i+2)
case chanTest <- i + 3:
fmt.Println("success write %d to channel", i+3)
case chanTest <- i + 4:
fmt.Println("success write %d to channel", i+4)
case chanTest <- i + 5:
fmt.Println("success write %d to channel", i+5)
case ok := <-chanTimeOut:
fmt.Println("chanTimeOut is ", ok, "time out !")
//default:
// fmt.Println("this channel is blocked")
}
//n := <-chanTest
//fmt.Println("this is %d : value : %d", i, n)
}
for i := 0; i < len(chanTest); i++ {
fmt.Println(<-chanTest)
}
fmt.Println("下面是测试 chanel 的 range用法 :")
data := make(chan int, 3)
data <- 1
data <- 2
data <- 3
go func() {
for v := range data {
fmt.Println(v)
}
exit <- true
}()
data <- 4
data <- 5
close(data)
<-exit
fmt.Println("下面是判断 chanel 是否关闭的用法 :")
chanClose := make(chan string)
go func() {
for {
if v, ok := <-chanClose; ok {
fmt.Println(v)
} else {
fmt.Println("close this channel")
break
}
}
exit <- true
}()
time.Sleep(2 * 1e9)
chanClose <- "ready to close"
close(chanClose)
<-exit
fmt.Println("下面是定义单项 chanel 的用法 :")
channel := make(chan int)
var cSend chan<- int = channel
var cReveice <-chan int = channel
go func() {
nRet := <-cReveice
//cReveice <- 2 invalid operation: cReveice <- 2 (send to receive-only type <-chan int)
fmt.Println(nRet)
exit <- true
}()
cSend <- 1
//nRet := <-cSend invalid operation: <-cSend (receive from send-only type chan<- int)
<-exit
fmt.Println("下面是多核分布式计算总数总和 :")
runtime.GOMAXPROCS(runtime.NumCPU())
fmt.Println("count is ", AllCount(13245678321, int64(runtime.NumCPU()), exit))
}
func SomeCount(nStart int64, nEnd int64, c chan int64) {
var nCount int64 = 0
for i := nStart; i < nEnd+1; i++ {
nCount = nCount + i
}
fmt.Println("start - ", nStart, "end - ", nEnd, ":count is ", nCount)
c <- nCount
}
func AllCount(nCount int64, nCPU int64, exit chan bool) int64 {
c := make(chan int64)
var i int64
for i = 0; i < nCPU; i++ {
go SomeCount((i*nCount)/nCPU, ((i+1)*nCount)/nCPU, c)
}
var nInt64 int64 = 0
for i = 0; i < nCPU; i++ {
nInt64 = nInt64 + <-c
}
return nInt64
}
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 修改Mysql数据库的数据存储位置
- 使用Caddy搭建TLS1.3+HTTP2代理
- 一文带你了解Python爬虫(一)——基本原理介绍
- 关于修改window.navigator.webdriver代码失效问题
- 一文带你了解Python爬虫(二)——四种常见基础爬虫方法介绍
- 当 snapshot 失败时发生了什么
- python 文件管理神器os.walk-文件指定日期整理程序
- 项目驱动-两日速成Docker日记
- python os模块 --- 操作系统接口模块
- 自动采集各种美女图片站并下载图和自动搭建图片站
- 修改其他函数的功能的神器——python装饰器
- AllTube:视频解析下载源码安装教程
- Zsh和Oh My Zsh的安装配置
- 程序猿怎么利用技术挣钱?——python量化实践
- 利用WireGuard建立IPv6隧道