go语言是互联网时代的语言,融合了众多互联网时代程序设计的特征。
并行与分布式支持。多核化和集群化是互联网时代的典型特征。
并发执行的“执行体”
执行体是个抽象的概念,在操作系统层面有多个概念与之对应,如操作系统自己掌管的进程(process)、进程内的线程(thread)以及进程内的协程 (coroutine,也叫轻量级线程)。多数语言在语法层面并不直接支持协程,而通过库的方式支持的协程的功能也并不完整,比如仅仅提供协程的创建、销毁与切换等能力。如果在这样的协程中调用一个同步IO操作,比如网络通信、本地文件读写,都会阻塞其他的并发执行协程,从而无法真正达到协程本身期望达到的目标。 Go语言在语言级别支持协程,叫goroutine。Go语言标准库提供的所有系统调用(syscall)操作,当然也包括所有同步IO操作,都会出让CPU给其他goroutine,这让事情变得非常简单。
go语言异步程序示例:
func run(arg string) {
// ...
}
func main() {
go run("test")
...
}
关于进程、线程、协程的区别可以参考如下几篇文章: