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