1. 并发模型与goroutine
Go语言以其强大的并发模型而闻名,它的核心机制是goroutine。goroutine是一种轻量级线程,由Go运行时负责调度。我们可以通过go关键字创建goroutine,而不需要像传统的线程编程那样关注底层的线程管理。
示例代码:
package main
import (
"fmt"
"time"
)
func helloWorld() {
fmt.Println("Hello, world!")
}
func main() {
go helloWorld()
time.Sleep(1 * time.Second)
}
在这个例子中,我们通过go helloWorld()创建了一个goroutine来执行helloWorld函数,而主函数不会等待helloWorld执行完就结束,展示了并发的特性。
2. 通道(Channel)
通道是goroutine之间进行通信和同步的关键机制。它提供了一种安全、高效的数据传输方式。通道分为有缓冲和无缓冲两种,用于满足不同的通信需求。
示例代码:
package main
import "fmt"
func main() {
ch := make(chan int, 1) // 创建一个有缓冲的通道
ch