Go语言的并发和并行
来源:互联网 发布:php 优惠券最优使用法 编辑:程序博客网 时间:2024/06/14 06:28
package mainimport ( "fmt")func loop(done chan bool) { for i := 0; i < 10; i++ { fmt.Print(i) } done <- true}func main() { done := make(chan bool) go loop(done) go loop(done) <-done <-done}
他的输出结果: 01234567890123456789
go不是会新起一个goroutine来运行loop函数吗。以前我们用线程去做类似任务的时候,系统的线程会抢占式地输出, 表现出来的是乱序地输出。而goroutine为什么是这样输出的呢?
关于并行和并发,下面这张图说明:
- 两个队列,一个Coffee机器,那是并发
- 两个队列,两个Coffee机器,那是并行
默认地, Go所有的goroutines只能在一个线程里跑 。
如果当前goroutine不发生阻塞,它是不会让出CPU给其他goroutine的, 所以上面的例子的输出会是一个一个goroutine进行的
真正的并行
为了达到真正的并行,runtime.GOMAXPROCS(2)试试看
package mainimport ( "fmt" "runtime")func loop(done chan bool) { for i := 0; i < 100; i++ { fmt.Printf("%d ", i) } done <- true}func main() { runtime.GOMAXPROCS(2) done := make(chan bool) go loop(done) go loop(done) <-done <-done}
这下会看到两个goroutine会抢占式地输出数据了。我们还可以这样显式地让出CPU时间:
package mainimport ( "fmt" "runtime")func loop(done chan bool) { for i := 0; i < 100; i++ { fmt.Printf("%d ", i) runtime.Gosched() //// 显式地让出CPU时间给其他goroutine } done <- true}func main() { // runtime.GOMAXPROCS(2) done := make(chan bool) go loop(done) go loop(done) <-done <-done}
总结
我们从例子中可以看到,默认的, 所有goroutine会在一个原生线程里跑
在同一个原生线程里,如果当前goroutine不发生阻塞,它是不会让出CPU时间给其他同线程的goroutines的,这是Go运行时对goroutine的调度,我们也可以使用runtime包来手工调度。
当一个goroutine发生阻塞,Go会自动地把与该goroutine处于同一系统线程的其他goroutines转移到另一个系统线程上去,以使这些goroutines不阻塞
http://www.cnblogs.com/hupengcool/p/3993823.html
0 0
- Go语言的并发和并行
- Go语言的并发和并行
- 【Go】区别并行和并发
- GO语言的并发
- go-并发与并行
- Go语言并发与并行学习笔记(一)
- Go语言并发与并行学习笔记(二)
- Go语言并发与并行学习笔记(三)
- Go语言并发与并行学习笔记(一)
- Go语言并发与并行学习笔记(二)
- Go语言并发与并行学习笔记(三)
- Go语言并发与并行学习笔记(一)
- Go语言并发与并行学习笔记(二)
- Go语言并发与并行学习笔记(一)
- Go语言并发与并行学习笔记(二)
- Go语言并发与并行学习笔记(三)
- go语言简单的并行控制方法
- Go 并发 、并行、线程池
- 体系结构
- 守护进程-解析
- Python之numpy教程(二):运算、索引、切片
- K均值聚类算法及MATLAB函数使用
- 【Leetcode】Longest Palindromic Substring
- Go语言的并发和并行
- php-联想搜索
- Android中xml和json文件的解析和创建
- 周练cf G - Restoring Painting 【数学 规律】
- 【Leetcode】Recover Binary Search Tree
- HackRF FM 发射机编写
- 哇咔咔咔,第一次优秀
- 图片的HTTP请求
- 线程-Pthread 笔记