go语言中的并发
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语言中的并发的更多相关文章
- Go语言中的并发编程
并发是编程里面一个非常重要的概念,Go语言在语言层面天生支持并发,这也是Go语言流行的一个很重要的原因. Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(你在用微信和两个女朋友聊天) ...
- UML语言中五大视图和九种图形纵览
UML语言纵览 视图 UML语言中的视图大致分为如下5种: 1.用例视图.用例视图强调从系统的外部参与者(主要是用户)的角度看到的或需要的系统功能. 2.逻辑视图.逻辑视图从系统的静态结构和动态行为角 ...
- Go语言基础之并发
并发是编程里面一个非常重要的概念,Go语言在语言层面天生支持并发,这也是Go语言流行的一个很重要的原因. Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(你在用微信和两个女朋友聊天) ...
- GO学习-(18) Go语言基础之并发
Go语言基础之并发 并发是编程里面一个非常重要的概念,Go语言在语言层面天生支持并发,这也是Go语言流行的一个很重要的原因. Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(你在用微 ...
- Golang语言系列-11-goroutine并发
goroutine 并发 概念 package main import ( "fmt" "time" ) /* [Go语言中的并发编程 goroutine] [ ...
- Go语言系列之并发编程
Go语言中的并发编程 并发与并行 并发:同一时间段内执行多个任务(宏观上并行,微观上并发). 并行:同一时刻执行多个任务(宏观和微观都是并行). Go语言的并发通过goroutine实现.gorout ...
- 【Golang详解】go语言中并发安全和锁
go语言中并发安全和锁 首先可以先看看这篇文章,对锁有些了解 [锁]详解区分 互斥锁.⾃旋锁.读写锁.乐观锁.悲观锁 Mutex-互斥锁 Mutex 的实现主要借助了 CAS 指令 + 自旋 + 信号 ...
- Java语言中的面向对象特性总结
Java语言中的面向对象特性 (总结得不错) [课前思考] 1. 什么是对象?什么是类?什么是包?什么是接口?什么是内部类? 2. 面向对象编程的特性有哪三个?它们各自又有哪些特性? 3. 你知 ...
- Rust语言:安全地并发
http://www.csdn.net/article/2014-02-26/2818556-Rust http://www.zhihu.com/question/20032903 Rust是近两年M ...
随机推荐
- [CI]CodeIgniter快速开发指南
---------------------------------------------------------------------------------------------------- ...
- Android Bug:Error:com.android.dex.DexException: Multiple dex files define Landroid/support/design/widget/CoordinatorLayout$LayoutParams;
项目编译通过,运行时出现异常: Error:com.android.dex.DexException: Multiple dex files define Landroid/support/desig ...
- SQL Server 生成 数据字典 / 数据库文档
1. 工具生成 2.SQL语句生成 参考地址:http://blog.csdn.net/qq289523052/article/details/22174721 1.在 表 上右键 - 扩展属性 - ...
- 学JS的心路历程Day26 - PixiJS -入坑
后来知道也可以透过canvas让网页动起来! 而PixiJS是使用WebGL在canvas上绘制内容与制作动态 且同时有下列特色: 支持多点触控 掩码与混合模式 可外加WebGL滤镜 多装置支持 等等 ...
- Java中的IO流(一)
一,IO流的分类 A,按照操作的对象不同可分为字节流与字符流 B,按照流的方向不同可分为输入(指从外部存储设备拿文件到内存)流也叫读与输出(指从内存把文件写入到外部存储设备)流也叫写 注:字节流可以操 ...
- RGB图片取大于阈值部分
#include<opencv2\opencv.hpp> #include <iostream> using namespace cv; using namespace std ...
- eclipse老运行上一个程序之原因总结
运行eclipse有的时候不运行刚写的类,老是运行别的以前的类,删除了以前的类就啥都不运行.找了好久的原因,最后发现,刚写的类没有main()或者有误.这和java的特点有关,程序的运行总是main( ...
- 05_ssm基础(二)之mybatis优化
06.mybatis优化之Mybatis工具类提取 优化原则(见官方文档): mybatis工具类存放位置: mybatis工具类代码: package com.day01.ssm.mybatisDe ...
- 03_java基础(九)之综合练习与考核评估
25.综合练习之车站业务分析 完成步骤: 需求: 以车站业务对车票做增删改查操作 1.建立数据库 2.建立车票表 3.建立java项目结构(model\dao\service\test) 4.创建mo ...
- 关于订单BOM替换组件不成功的问题
替换成功的案例: SELECT * FROM IN_BOM_DETAILS WHERE BOM_ID='00161815_2023_01P19'; --成品编码:000000101011006433P ...