Golang 的并发模式利用以下原语:goroutine(轻量级并发执行单元)、channel(通信通道)、sync.Mutex(互斥锁)。实战案例使用这些原语并行执行任务,并使用无缓冲 channel 存储任务结果,使用 sync.Mutex 保护对结果的并发访问,最终收集并打印结果。
Golang 是一个高并发、高性能的编程语言,其内置的并发原语提供了强大的并发功能。本文将深入探讨 Golang 的并发模式,并通过实战案例演示如何有效地管理并发。
goroutine 是 Golang 的轻量级并发执行单元,可以并发执行不同的任务。go
关键字用于创建新的 goroutine。
channel 是通信通道,用于在 goroutine 之间传递数据。channel 通常是无缓冲或有缓冲的。
sync.Mutex 用于互斥锁,防止并发访问共享数据。
下面是一个使用 goroutine 和 channel 并发执行多个任务的示例:
package main import ( "fmt" "sync" "time" ) func main() { // 创建一个无缓冲 channel,用于存储任务结果 resultChan := make(chan int) // 创建一个 mutex,用于控制对结果的访问 var mu sync.Mutex // 创建并启动 10 个 goroutine 并发执行任务 for i := 0; i < 10; i++ { go func(i int) { result := i * i fmt.Printf("Goroutine %d completed with result %dn", i, result) mu.Lock() resultChan <- result mu.Unlock() }(i) } // 等待所有 goroutine 完成任务并收集结果 results := make([]int, 10) for i := 0; i < 10; i++ { results[i] = <-resultChan } // 打印最终结果 fmt.Println("Final results:", results) time.Sleep(time.Second) // 等待 goroutine 退出 }
在这个示例中:
resultChan
来存储任务结果。sync.Mutex
来保护对结果的并发访问。resultChan
。该示例展示了如何使用 goroutine 和 channel 并发执行任务,如何保护共享数据,以及如何等待 goroutine 优雅退出。通过理解这些概念,您可以有效地管理并发并构建高性能的 Golang 应用程序。
使用 RabbitMQ 时,即使设置了 delivery_mode: 1(表示消息是非持久性的),消息仍可能被写入磁盘,原因如下: 1. **队列持久化**:如果队列本身被设置为持久化(durable),那么即使消息是非持久性的,RabbitMQ 也会将这些消息写入磁盘。这是因为队列持久化意味着队列的定义和队列中的消息都需要在服务器重启后保留。 2. **内存压力**:RabbitMQ 会根据内存使用情况将消息从内存转移到磁盘。当内存压力增加时,即使消息是非持久性的,RabbitMQ 也会将它们写入磁
如何使用 Golang 函数对数据结构进行深度优先遍历?
Go语言函数返回值类型推断机制
golang框架开发实战问答录:疑难问题汇总及解答
GoLand无法解析Go.mod文件中的包怎么办?
Debian OpenSSL配置难吗