一、并行和并发的概念编程
并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。安全
并发(concurrency):指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具备多个进程同时执行的效果,但在微观上并非同时执行的,只是把时间分红若干段,使多个进程快速交替的执行。并发
二、并行和并发的区别线程
- 并发是两个队列交替使用一台咖啡机
- 并行是两个队列同时使用两台咖啡机
三、并发和并行原理图设计
图1blog
四、go语言并发优点队列
有人把Go比做21世纪的C语言,第一是由于Go语言设计简单,第二,21世纪最重要的就是并行程序设计,而Go从语言层面就支持了并行。同时,并发程序的内存管理有时候是很是复杂的,而Go语言提供了自动垃圾回收机制。进程
Go语言为并发编程而内置的上层API基于CSP(communicating sequential processes, 顺序通讯进程)模型。这就意味着显式锁都是能够避免的,由于Go语言经过相册安全的通道发送和接受数据以实现同步,这大大地简化了并发程序的编写。内存
通常状况下,一个普通的桌面计算机跑十几二十个线程就有点负载过大了,可是一样这台机器却能够轻松地让成百上千甚至过万个goroutine进行资源竞争。资源