登录
首页 >  Golang >  Go教程

Golang 函数:如何并发地运行多个 goroutine?

时间:2024-09-30 15:25:48 267浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习Golang的朋友们,也希望在阅读本文《Golang 函数:如何并发地运行多个 goroutine?》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

Golang 中可使用 goroutine 实现并发,创建 goroutine 时使用 go 关键字,管理 goroutine 时使用 WaitGroup,并行执行 goroutine 时使用 Mutex。在实战案例中,可以通过并发获取网页内容来体验并发的优势,通过 goroutine 并行获取多个网页内容,并通过 WaitGroup 等待所有 goroutine 完成,最后通过 channel 获取所有并行获取的数据。

Golang 函数:如何并发地运行多个 goroutine?

Golang 函数:并发地运行多个 Goroutine

在 Golang 中,goroutine 是轻量级的协程,可以并发执行。这篇文章将介绍如何创建、管理、并行执行多个 goroutine。

创建 Goroutine

使用 go 关键字创建 Goroutine:

go func() {
  // Goroutine 体
}

管理 Goroutine

WaitGroup 用于等待一组 goroutine 完成执行:

import "sync"

var wg sync.WaitGroup

在 goroutine 中,调用 wg.Done() 来通知 WaitGroup 完成:

wg.Done()

在主函数中,调用 wg.Wait() 来等待所有 goroutine 完成:

wg.Wait()

并行执行 Goroutine

使用 sync.Mutex 来确保并行执行时数据的并发访问安全:

import "sync"

var mu sync.Mutex

在并行执行代码块时,使用 mu.Lock()mu.Unlock() 来控制对共享数据的访问:

mu.Lock()
// 并行执行代码
mu.Unlock()

实战案例:并发获取网页内容

package main

import (
    "fmt"
    "io"
    "net/http"
    "time"
)

func fetchURL(url string, wg *sync.WaitGroup, results chan<- string) {
    resp, err := http.Get(url)
    if err != nil {
        fmt.Println("Error fetching URL:", err)
        return
    }
    defer resp.Body.Close()
    body, err := io.ReadAll(resp.Body)
    if err != nil {
        fmt.Println("Error reading body:", err)
        return
    }
    results <- string(body)
    wg.Done()
}

func main() {
    urls := []string{"https://example.com", "https://google.com", "https://amazon.com"}
    results := make(chan string)
    var wg sync.WaitGroup
    wg.Add(len(urls))
    for _, url := range urls {
        go fetchURL(url, &wg, results)
    }
    wg.Wait()
    close(results)

    // 获取所有并行获取的数据
    for result := range results {
        fmt.Println(result)
    }
}

理论要掌握,实操不能落!以上关于《Golang 函数:如何并发地运行多个 goroutine?》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>