摘要:
并发打印 使用无缓冲通道往里面装入数据时,装入方将被阻塞,直到另外通道在另外一个 goroutine 中被取出。同样,如果通道中没有放入任何数据,接收方试图从通道中获取数据时,同样被阻塞。发送和接收的操作是同步完成的。 package main import "fmt" func printer(c 阅读全文
摘要:
在多个 goroutine 间通信的管道——通道(Channel) 单纯地将函数并发执行是没有意义的。函数与函数间需要交换数据才能体现并发执行函数的意义。 虽然可以使用共享内存进行数据交换,但是共享内存在不同的 goroutine 中容易发生竟态问题。为了保证数据交换的正确性,必须使用互斥量对内存进 阅读全文
摘要:
调整并发的运行性能(GOMAXPROCS) 在 Go 运行时(runtime)实现了一个小型的任务调度器。这套调度器的工作原理类似操作系统调度线程,Go 程序调度器可以高效地将 CPU 资源分配给每一个任务。传统逻辑中,开发者需要维护 线程池中线程 与 CPU 核心数量的对应关系。同样的,Go 中也 阅读全文