go语言之进阶篇并行和并发的区别与go语言并发优点

一、并行和并发的概念编程

并行(parallel)指在同一时刻,有多条指令在多个处理器上同时执行。安全

并发(concurrency)指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具备多个进程同时执行的效果,但在微观上并非同时执行的,只是把时间分红若干段,使多个进程快速交替的执行。并发

 

二、并行和并发的区别线程

  • 并发是两个队列交替使用一台咖啡机 
  • 并行是两个队列同时使用两台咖啡机

三、并发和并行原理图设计

  

 

                                              图1blog

 

四、go语言并发优点队列

有人把Go比做21世纪的C语言,第一是由于Go语言设计简单,第二,21世纪最重要的就是并行程序设计,而Go从语言层面就支持了并行。同时,并发程序的内存管理有时候是很是复杂的,而Go语言提供了自动垃圾回收机制。进程

Go语言为并发编程而内置的上层API基于CSP(communicating sequential processes, 顺序通讯进程)模型。这就意味着显式锁都是能够避免的,由于Go语言经过相册安全的通道发送和接受数据以实现同步,这大大地简化了并发程序的编写。内存

通常状况下,一个普通的桌面计算机跑十几二十个线程就有点负载过大了,可是一样这台机器却能够轻松地让成百上千甚至过万个goroutine进行资源竞争。资源

相关文章
相关标签/搜索