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 是编写高效并发程序的关键。

相关推荐
llz_1123 小时前
web-第二次课后作业
前端·后端·web
红尘散仙9 小时前
我把终端小说阅读器接上了 AI Agent:TRNovel 现在能用 skill 生成书源了
人工智能·后端·rust
卷毛的技术笔记10 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
会编程的土豆10 小时前
Go 语言反射(Reflection)详解
开发语言·后端·golang
喵个咪10 小时前
GoWind Toolkit Go后端代码生成 完整全流程实战
后端·go·orm
basketball61611 小时前
Go 语言从入门到进阶:4. 数组和MAP使用方法总结
开发语言·后端·golang
qq_25183645711 小时前
SpringBoot+Vue 共享电池柜管理系统 完整实现 前后端分离项目实战 完整代码
vue.js·spring boot·后端
zhangxingchao11 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
IT_陈寒12 小时前
Vite打包时遇到的坑,原来问题出在这里
前端·人工智能·后端
ayqy贾杰14 小时前
基层管理的三板斧,在AI时代行不通了
前端·后端·团队管理