四个方面特点: 1. 并发支持 对于及时通讯、网络编程等方面,并发支持一定是并不可少的。goroutine,用户态"线程",大家所说的协程,支持并发操作。已经提供了 sync 包来解决并发操作的并发安全问题。 sync 包中有:互斥锁、读写锁、原子操作(atomic)、WaitGroup等。同时,结合IPC(进程间通信),常被称道的 channel。 2. 内存消耗方面 每个 goroutine (协程) 默认占用内存远比 Java 、C 的线程少。goroutine: 2KB 线程: 8MB 3. 线程/goroutine 切换(调度)开销方面 线程/goroutine 切换开销方面,goroutine 远比线程小线程: 涉及模式切换(从用户态切换到内核态)、16个寄存器、PC、SP...等寄存器的刷新等。goroutine: 只有三个寄存器的值修改 - PC / SP / DX. 4. 网络操作 Golang 提供了 net 包,里面有方便网络操作的包,比如TCP/UDP/HTTP...等多种第四层以及七层网络的支持,用起来也很方便。
四个方面特点:
1. 并发支持
2. 内存消耗方面
3. 线程/goroutine 切换(调度)开销方面
4. 网络操作