1.`goroutine`具有可增长的分段堆栈。这意味着它们只在需要时才会使用更多内存。
2.`goroutine`的启动时间比线程快。
3.`goroutine`原生支持利用channel安全地进行通信。
4.`goroutine`共享数据结构时无需使用互斥锁。
1、go语言的并发是基于goroutine的,goroutine类似于线程,但又不是线程,可以将goroutine理解为是一种虚拟的线程,
2、go语言运行的时候,会调用goroutine,并将goroutine合理的分配到每个cpu中,最大限度的使用cpu的性能,
3、开启一个goroutine消耗是非常小的(大概是2kb),所以可以轻松的创建数以百计的goroutine。