8.4 Go select

Go语言引入了select关键字,用于处理异步IO问题,语义和switch特别相似。语法由select开始,每个条件由case语句来描述。每个case语句必须是IO操作

select {
case <-chan1:
//如果读取到channel的数据,就执行这里
case chan2<-1:
//如果成功向chan2写入数据,就执行这里
default:
//上述都失败了,进入这里
}

案例

使用select可以解决从管道取数据的阻塞问题

package main

import (
"fmt"
"time"
) func main() {
//定义一个管道
intChan := make(chan int, 10) //循环写入数据
for i := 0; i < 10; i++ {
intChan <- i
}
//定义管道,可以写入string
strChan := make(chan string, 5)
for i := 0; i < 5; i++ {
//格式化后写入string数据
strChan <- "hello" + fmt.Sprintf("%d", i)
}
//传统的for循环遍历,必须close关闭channel,否则造成死锁
//但是到底关闭哪个channel,并不那么容易选择
//加上for无线循环,匹配所有的case,直到结束return
for {
select {
//如果有数据被读取到,进入这个分支,并且intChan没关闭的话,也会自动匹配下一个case
case v := <-intChan:
fmt.Printf("从intChan读取到数据%d\n", v)
time.Sleep(time.Second)
case v2 := <-strChan:
fmt.Printf("从strChan中读取到数据%s\n", v2)
time.Sleep(time.Second)
default:
fmt.Printf("什么也没读到,再见\n")
time.Sleep(time.Second)
return
}
} }

1.1.1. waitGroup等待组

package main

import (
"fmt"
"math/rand"
"sync"
"time"
) func main() {
/*
同步等待组:WaitGourp,执行了wait的goroutine,要等待同步等待组中的其他的goroutine执行完毕。。
内置的计数器:counter:0
Add(),设置counter的值
Done(),将counter减一,同Add(-1) 以上两个方法可以设置counter的值,注意不能为负数,否则会引发恐慌。 Wait(),哪个goroutine执行了,那么就会被阻塞,直到counter为0。解除阻塞
*/
var wg sync.WaitGroup
//fmt.Printf("%T\n",wg)
//fmt.Println(wg)
wg.Add(2) go printNum1(&wg)
go printNum2(&wg) wg.Wait() //main,进入阻塞状态,底层计数器为0,接触阻塞。。
//time.Sleep(1*time.Second)
fmt.Println("main。。接触阻塞。。结束了。。。")
} func printNum1(wg *sync.WaitGroup) {
rand.Seed(time.Now().UnixNano())
for i := 1; i <= 100; i++ {
fmt.Println("子goroutine1,i:", i)
time.Sleep(time.Duration(rand.Intn(1000))) //
}
wg.Done() //计数器减一
} func printNum2(wg *sync.WaitGroup) {
for j := 1; j <= 100; j++ {
fmt.Println("\t子goroutine2,j:", j)
time.Sleep(time.Duration(rand.Intn(1000)))
}
wg.Done()
}

8.4 Go select的更多相关文章

  1. 最全的ORACLE-SQL笔记

    -- 首先,以超级管理员的身份登录oracle sqlplus sys/bjsxt as sysdba --然后,解除对scott用户的锁 alter user scott account unloc ...

  2. Matplotlib数据可视化(6):饼图与箱线图

    In [1]: from matplotlib import pyplot as plt import numpy as np import matplotlib as mpl mpl.rcParam ...

  3. SELECT INTO 和 INSERT INTO SELECT 两种表复制语句

    Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...

  4. select、poll、epoll之间的区别总结

    select.poll.epoll之间的区别总结 05/05. 2014 select,poll,epoll都是IO多路复用的机制.I/O多路复用就通过一种机制,可以监视多个描述符,一旦某个描述符就绪 ...

  5. LINQ to SQL Select查询

    1. 查询所有字段 using (NorthwindEntities context = new NorthwindEntities()) { var order = from n in contex ...

  6. ADO.NET一小记-select top 参数问题

    异常处理汇总-后端系列 http://www.cnblogs.com/dunitian/p/4523006.html 最近使用ADO.NET的时候,发现select top @count xxxx 不 ...

  7. iosselect:一个js picker项目,在H5中实现IOS的select下拉框效果

    具体文档和demo可以访问github:https://github.com/zhoushengmufc/iosselect 移动端浏览器对于select的展示样式是不一致的,ios下是类似原生的pi ...

  8. SQL Server中SELECT会真的阻塞SELECT吗?

    在SQL Server中,我们知道一个SELECT语句执行过程中只会申请一些意向共享锁(IS) 与共享锁(S), 例如我使用SQL Profile跟踪会话86执行SELECT * FROM dbo.T ...

  9. (转载) Linux IO模式及 select、poll、epoll详解

    注:本文是对众多博客的学习和总结,可能存在理解错误.请带着怀疑的眼光,同时如果有错误希望能指出. 同步IO和异步IO,阻塞IO和非阻塞IO分别是什么,到底有什么区别?不同的人在不同的上下文下给出的答案 ...

  10. 基于select的python聊天室程序

    python网络编程具体参考<python select网络编程详细介绍>. 在python中,select函数是一个对底层操作系统的直接访问的接口.它用来监控sockets.files和 ...

随机推荐

  1. 20199308《Linux内核原理与分析》第十二周作业

    一.实验简介 竞态条件是指多个线程同时访问或者操作同一块数据,运行的结果依赖于不同线程访问数据的顺序.如果一个拥有root权限的程序存在竞态条件漏洞的话,攻击者可以通过运行一个平行线程与漏洞程序竞争, ...

  2. Vsftp用户限制

    背景 Oracle全库备份,异地备份 在实现异地备份后,由第三方人员登录服务器拉取dmp文件. 为了确保安全,创建一个特定ftp账号用于第三方人员使用 要求 1.可以登录服务器 2.可以拉取dmp文件 ...

  3. docker企业级镜像仓库Harbor管理

    Harbor概述 Harbor是由VMWare公司开源的容器镜像仓库.事实上,Harbor是在Docker Registry上进行了相应的企业级扩展,从而获得了更加广泛的应用,这些新的企业级特性包括: ...

  4. 日志分析工具ELK(四)

    Logstash收集TCP日志 #Input plugins TCP插件 所需的配置选项 tcp { port =>... } [root@linux-node1 ~]# cat tcp.con ...

  5. 标准库os

    os模块 提供对操作系统进行调用的接口 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 os ...

  6. POJ 2136 Vertical Histogram(当时写的比较恶心,优化一下)

    Vertical Histogram Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 21223 Accepted: 10048 ...

  7. 多线程高并发编程(7) -- Future源码分析

    一.概念 A Future计算的结果. 提供方法来检查计算是否完成,等待其完成,并检索计算结果. 结果只能在计算完成后使用方法get进行检索,如有必要,阻塞,直到准备就绪. 取消由cancel方法执行 ...

  8. OSG程序设计之osg::NodeVisitor

    本文所有内容来自<OpenSceneGraph三维渲染引擎设计与实践>一书. 本文主要讨论的是OSG中节点的访问. 对于节点的访问是从节点接收一个访问器开始的,用户执行某个节点的accep ...

  9. CtsSecurityTestCases#ListeningPortsTest定位tcp端口与pid

    CtsSecurityTestCases#ListeningPortsTest定位tcp端口与pid [问题描述] cts失败项 armeabi-v7a CtsSecurityTestCases an ...

  10. 初识CoAP协议

    前言 本文介绍什么是CoAP,以及如何在物联网设备上使用它.CoAP是一种物联网协议,具有一些专门为受约束的设备而设计的有趣功能.还有其他一些可用于构建物联网解决方案的IoT协议,例如MQTT等. 物 ...