Go 语言并发编程:Goroutine 与 Channel 实战指南

Go 语言并发编程:Goroutine 与 Channel 实战指南

一、什么是 Goroutine

Goroutine 是 Go 语言中最强大的特性之一,它是一种轻量级的线程,由 Go 运行时管理。与操作系统线程相比,Goroutine 的启动开销极小,内存占用仅约 2KB。

二、Goroutine 基础用法

复制代码
package main

import (
    "fmt"
    "time"
)

func sayHello() {
    fmt.Println("Hello from Goroutine!")
}

func main() {
    go sayHello()
    time.Sleep(time.Second)
    fmt.Println("Main function done")
}

三、Channel 通道通信

Channel 是 Goroutine 之间通信的管道,遵循"不要通过共享内存来通信,而要通过通信来共享内存"的原则。

复制代码
package main

import "fmt"

func worker(ch chan int) {
    for i := 0; i < 5; i++ {
        ch <- i
    }
    close(ch)
}

func main() {
    ch := make(chan int)
    go worker(ch)
    
    for num := range ch {
        fmt.Printf("Received: %d
", num)
    }
}

四、实战:并发处理任务

复制代码
package main

import (
    "fmt"
    "sync"
    "time"
)

func processTask(id int, wg *sync.WaitGroup) {
    defer wg.Done()
    fmt.Printf("Task %d started
", id)
    time.Sleep(100 * time.Millisecond)
    fmt.Printf("Task %d completed
", id)
}

func main() {
    var wg sync.WaitGroup
    
    for i := 1; i <= 10; i++ {
        wg.Add(1)
        go processTask(i, &wg)
    }
    
    wg.Wait()
    fmt.Println("All tasks completed!")
}

五、最佳实践

  • 避免 Goroutine 泄漏:确保每个 Goroutine 都能正常退出
  • 使用 context 控制生命周期
  • 合理使用 buffered channel
  • 使用 sync.WaitGroup 等待并发任务完成

总结

Go 语言的并发模型简洁而强大,掌握 Goroutine 和 Channel 是编写高效并发程序的关键。

相关推荐
葫芦和十三5 小时前
图解 MongoDB 07|索引类型:七种索引,七种访问形状
后端·mongodb·agent
朦胧之7 小时前
AI 编程-老项目改造篇
java·前端·后端
爱勇宝10 小时前
我做了一个只用来搜歌词的小 App
android·前端·后端
IT_陈寒11 小时前
SpringBoot自动配置坑了我一晚上,原来问题出在这
前端·人工智能·后端
SelectDB11 小时前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
SelectDB11 小时前
秒级弹性、最高降本 70%:SelectDB Serverless 如何重塑云数仓资源效率
大数据·后端·云原生
PinkSun11 小时前
Spring AI ChatMemory踩坑实录:重启丢数据、Agent丢记忆、对话溢出
后端·ai编程
壹方秘境12 小时前
我用Go语言开发了一个跨平台的HTTPS抓包和调试工具
前端·后端·ios
神秘面具男12 小时前
HarmonyOS 6.0跨端远程控制
前端·后端