package main;

import (
"fmt"
"runtime"
"sync"
) //goruntine奉行通过通信来共享内存,而不是共享内存来通信
//channel是goruntine沟通的桥梁,大都是阻塞同步的
//通过make创建,close关闭
//channel是引用类型
//使用for range来迭代操作channel
//可设置单向或双向通道
//可设置缓存大小,在未被填满前不会发生阻塞 func main() {
//这里需要设置chan的类型
ch := make(chan bool);
go func() {
fmt.Println("run...");
ch <- true;
}();
//这里是阻塞的,等到匿名函数执行完成,给ch设置为true时
//这里能读取出数据时,就退出。
<-ch; ch1 := make(chan bool);
go func() {
fmt.Println("run...");
ch1 <- true;
close(ch1);
}();
//对chan进行迭代操作时,必须在某个地方关闭该chan,不然会发生死锁
for v := range ch1 {
fmt.Println(v);
} //有缓存是异步的
ch2 := make(chan bool, 1);
go func() {
fmt.Println("run...");
<-ch2;
}();
ch2 <- true; //使用多核
runtime.GOMAXPROCS(runtime.NumCPU());
ch3 := make(chan bool, 10);
for i := 0; i < 10; i++ {
go run(ch3, i);
}
//这里读取10次,跟上面go run()执行次数相同
//保证10次运行都执行完,才退出
for i:= 0; i < 10; i++ {
<-ch3;
} //这里创建任务
wg := sync.WaitGroup{};
wg.Add(10);
for i := 0; i < 10; i++ {
go run2(&wg, i);
}
//等待所有任务完成
wg.Wait(); //有多个chan时,如何处理
ch4, ch5 := make(chan int), make(chan string);
//用于判断是否关闭
ch6 := make(chan bool);
go func() {
for {
select {
case v, ok := <-ch4:
if !ok {
ch6 <- true;
break;
}
fmt.Println(v);
case v, ok := <-ch5:
if !ok {
ch6 <- true;
break;
}
fmt.Println(v);
}
}
}(); ch4 <- 1;
ch4 <- 2;
ch5 <- "hello";
ch5 <- "world"; close(ch4);
close(ch5);
//循环读取二次
for i := 0; i < 2; i++ {
<-ch6;
} } func run(ch chan bool, ix int) {
a := 0;
for i := 1; i < 10000; i++ {
a += i;
}
fmt.Println(ix, a); //给chan传递true,说明该run执行结束
ch <- true;
} func run2(wg *sync.WaitGroup, ix int) {
a := 0;
for i := 1; i < 10000; i++ {
a += i;
}
fmt.Println(ix, a);
//任务完成
wg.Done();
}

  

go语言中的并发的更多相关文章

  1. Go语言中的并发编程

    并发是编程里面一个非常重要的概念,Go语言在语言层面天生支持并发,这也是Go语言流行的一个很重要的原因. Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(你在用微信和两个女朋友聊天) ...

  2. UML语言中五大视图和九种图形纵览

    UML语言纵览 视图 UML语言中的视图大致分为如下5种: 1.用例视图.用例视图强调从系统的外部参与者(主要是用户)的角度看到的或需要的系统功能. 2.逻辑视图.逻辑视图从系统的静态结构和动态行为角 ...

  3. Go语言基础之并发

    并发是编程里面一个非常重要的概念,Go语言在语言层面天生支持并发,这也是Go语言流行的一个很重要的原因. Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(你在用微信和两个女朋友聊天) ...

  4. GO学习-(18) Go语言基础之并发

    Go语言基础之并发 并发是编程里面一个非常重要的概念,Go语言在语言层面天生支持并发,这也是Go语言流行的一个很重要的原因. Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(你在用微 ...

  5. Golang语言系列-11-goroutine并发

    goroutine 并发 概念 package main import ( "fmt" "time" ) /* [Go语言中的并发编程 goroutine] [ ...

  6. Go语言系列之并发编程

    Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(宏观上并行,微观上并发). 并行:同一时刻执行多个任务(宏观和微观都是并行). Go语言的并发通过goroutine实现.gorout ...

  7. 【Golang详解】go语言中并发安全和锁

    go语言中并发安全和锁 首先可以先看看这篇文章,对锁有些了解 [锁]详解区分 互斥锁.⾃旋锁.读写锁.乐观锁.悲观锁 Mutex-互斥锁 Mutex 的实现主要借助了 CAS 指令 + 自旋 + 信号 ...

  8. Java语言中的面向对象特性总结

    Java语言中的面向对象特性 (总结得不错) [课前思考]  1. 什么是对象?什么是类?什么是包?什么是接口?什么是内部类?  2. 面向对象编程的特性有哪三个?它们各自又有哪些特性?  3. 你知 ...

  9. Rust语言:安全地并发

    http://www.csdn.net/article/2014-02-26/2818556-Rust http://www.zhihu.com/question/20032903 Rust是近两年M ...

随机推荐

  1. happyxiaofan的程序员书单

    转自   happyxiaofan 读书的看法 从15年7月至今,研究生期间读了不少书,读书让我学到了很多,也是提升技术能力的一个重要手段.可能很多人嫌读书太花时间,曾经的我一度也是这么认为的,觉得一 ...

  2. Mybatis动态sql及性能优化-3

    内容简介 1.回顾 2.动态sql 3.性能优化 懒加载机制 一级缓存 二级缓存 一.回顾 1.config文件常用标签 properties标签:引入外部properties文件资源. settin ...

  3. c 时间 学习

    linux #include <stdio.h> #include <time.h> int main(int argc,char **argv) { //两种时间的获取方法 ...

  4. zTree插件 角色、部门、人员分类选择

    // 传参数调用 function test(){roleOrOrgSelect(3,function(data){console.log(data);});} /** * * @param type ...

  5. Android 深入浅出 - 进程生命周期(Process Lifecycle)

    Android 5 个进程等级 1. Foreground Process : 2 .Visible Process : 3. Service Process : 4. Background Proc ...

  6. BOS物流项目第十一天(补充)

    上节课我们在添加权限时,把选择父功能点做成这种效果,不太好,我们进行升级优化. 1.我们对jsp页面进行修改,主要是改了样式. 2.重新编写我们dao层的代码 3.在我们查看父项的时候自动查找子项,我 ...

  7. Oracle11g服务详细介绍

    Oracle11g服务详细介绍及哪些服务是必须开启的? Oracle ORCL VSS Writer Service Oracle卷映射拷贝写入服务,VSS(Volume Shadow Copy Se ...

  8. hbase 调试各种报错

    1.master is initializing 怎么都不知道怎么回事,直接从hbase 2.0 换到了 hbase 2.1 2.java.lang.ClassNotFoundException: o ...

  9. ./configure: error: the HTTP rewrite module requires the PCRE library解决

    ./configure: error: the HTTP rewrite module requires the PCRE library解决   有时候,我们需要单独安装nginx,来处理大量的下载 ...

  10. Java的map键值对的用法,map的遍历,Entry对象的使用

    思路: 1.定义集合 2.存储数据 3.添加元素 4.遍历 4.1将需要遍历的集合的键封装到set集合中(这用到了entrySet方法,和Entry对象) 4.2声明迭代器或者用for增强循环 4.3 ...