并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。
并发(concurrency):指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,使多个进程快速交替的执行。
goroutine
goroutine是比线程更小的工作单元,go语言内部实现了goroutine之间的内存共享,它比thread更易用、更高效、更轻便。
创建goroutine
只需要在函数调用语句前添加"go"关键字,就可以创建并发执行单元。当一个程序启动时,其主函数即在一个单独的goroutine中运行,称为main goroutine。当主协程结束的时候,子协程也会自动结束。
Gosched
runtime包的方法,让出时间片,让其它协程先执行
Goexit
runtime 包的方法,终止所在协程
GOMAXPROCS
runtime包的方法,获取最大核心数,指定使用核心数
channel
channel是内置的数据结构,用于读取发送数据,无数据时,读取数据会阻塞,设置了最大写入数据时,写满capacity个元素时,写入阻塞。
channel创建
make(chan Type)
make(chan Type, capacity)
channel读写
ch <- 666
<- ch
无缓冲的channel
make(chan Type)
make(chan Type,0)
有缓冲的channel
是一种在被接受前能存储一个或多个值得channel
make(chan Type,3)
单向channel
var send chan<- int
var receiver <-chan int