首页 > 编程语言 >掌握Go语言:Go 并发编程,轻松应对大规模任务处理和高并发请求(34)

掌握Go语言:Go 并发编程,轻松应对大规模任务处理和高并发请求(34)

时间:2024-04-09 13:33:50浏览次数:13  
标签:wg fmt 34 并发 func Go main

并发是 Go 语言的一个重要特性,通过 goroutine 和 channel,Go 提供了简单而强大的并发编程模型。goroutine 是轻量级的线程,可以在程序中并发执行任务,而 channel 则是用于 goroutine 之间的通信的管道。

Go 并发应用场景

1. 并行计算

应用场景:在需要处理大量计算密集型任务时,可以使用并发来提高计算速度。

示例:

package main

import (
    "fmt"
    "sync"
)

func main() {
    var wg sync.WaitGroup
    numTasks := 10

    for i := 0; i < numTasks; i++ {
        wg.Add(1)
        go func(taskID int) {
            defer wg.Done()
            result := doHeavyCalculation(taskID)
            fmt.Println("Task", taskID, "Result:", result)
        }(i)
    }

    wg.Wait()
}

func doHeavyCalculation(taskID int) int {
    // 模拟耗时计算
    return taskID * 2
}
2. 并发请求处理

应用场景:在网络服务中,需要处理大量的并发请求,可以使用并发来提高请求处理能力。

示例:

package main

import (
    "fmt"
    "net/http"
)

func main() {
    http.HandleFunc("/", handler)
    http.ListenAndServe(":8080", nil)
}

func handler(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintf(w, "Hello, %s!", r.URL.Path[1:])
}
3. 数据流处理

应用场景:在数据处理任务中,需要对数据进行并发处理和传递。

示例:

package main

import "fmt"

func main() {
    dataStream := make(chan int)
    resultStream := make(chan int)

    go produceData(dataStream)
    go processData(dataStream, resultStream)
    go consumeData(resultStream)

    // 等待数据处理完成
    var input string
    fmt.Scanln(&input)
}

func produceData(out chan<- int) {
    for i := 0; i < 10; i++ {
        out <- i
    }
    close(out)
}

func processData(in <-chan int, out chan<- int) {
    for data := range in {
        out <- data * 2
    }
    close(out)
}

func consumeData(in <-chan int) {
    for result := range in {
        fmt.Println("Processed result:", result)
    }
}

Go 并发注意事项

1. 避免竞态条件

注意事项:并发执行的 goroutine 可能会访问和修改共享数据,需要避免出现竞态条件,即多个 goroutine 同时修改同一份数据导致结果不确定。

示例:

package main

import (
    "fmt"
    "sync"
)

func main() {
    var counter int
    var wg sync.WaitGroup
    numWorkers := 10

    for i := 0; i < numWorkers; i++ {
        wg.Add(1)
        go func() {
            defer wg.Done()
            // 临界区操作
            counter++
        }()
    }

    wg.Wait()
    fmt.Println("Counter:", counter)
}
2. 使用互斥锁

注意事项:在处理共享数据时,可以使用互斥锁来保护临界区,确保同一时间只有一个 goroutine 可以访问共享数据。

示例:

package main

import (
    "fmt"
    "sync"
)

func main() {
    var counter int
    var mu sync.Mutex
    var wg sync.WaitGroup
    numWorkers := 10

    for i := 0; i < numWorkers; i++ {
        wg.Add(1)
        go func() {
            defer wg.Done()
            // 加锁保护临界区操作
            mu.Lock()
            counter++
            mu.Unlock()
        }()
    }

    wg.Wait()
    fmt.Println("Counter:", counter)
}

总结

Go 语言通过 goroutine 和 channel 提供了简单而强大的并发编程模型,使得并发编程变得容易且高效。在应用中,可以利用并发来提高计算性能、处理并发请求、进行数据流处理等。同时,需要注意避免竞态条件,保护共享数据的一致性,合理使用互斥锁等并发控制机制。

标签:wg,fmt,34,并发,func,Go,main
From: https://blog.csdn.net/wenbingy/article/details/137547839

相关文章

  • AtCoder Beginner Contest 348 A-F 题解
    A-PenaltyKickQuestion高桥将在一场足球比赛中获得\(N\)个点球。对于第\(i\)个罚球,如果\(i\)是\(3\)的倍数,他将罚球失败,否则罚球成功。请打印他罚球的结果。Solution当\(i\%3==0\)时说明能被\(3\)整除Code#include<bits/stdc++.h>usingnamespacest......
  • COMP3334 端到端加密聊天web应用程序
    端到端加密聊天web应用程序2023/2024年第2学期如今,web服务是最重要的用户的常见应用程序形式暴露于。Web浏览器成为计算机上的流行应用程序使用户能够访问这些web服务。确保web服务的安全是对互联网至关重要。此外,隐私的一个重要特征现代。您的工作是实现端到端加密聊天web应用程......
  • GO语言实现TCP端口转发
    12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061package main import (    "fmt"    "log"    "net&......
  • MongoDB 中索引的构建阶段
    1.Xlock收到创建索引的请求时,会在集合上获取排他的X锁。该锁会停止该集合上的所有读/写操作{"t":{"$date":"2024-03-13T05:29:35.925+00:00"},"s":"I","c":"INDEX","id":20438,"ctx":"conn15536&quo......
  • Django后端如何限制上传文件大小
    在Django中,对上传文件大小进行限制可以通过几种不同的方法来实现。这包括在表单层面、视图层面或通过设置Django项目的全局配置。以下是一些常用的方法:方法1:使用Django设置限制文件大小在Django的settings.py文件中,你可以设置DATA_UPLOAD_MAX_MEMORY_SIZE来限制上传文件的大......
  • 聊聊ChatGLM3多用户并发API调用的问题
    转载请备注出处:https://www.cnblogs.com/zhiyong-ITNote背景目前在公司内部4张A10的GPU服务器上部署了ChatGLM3开源模型;然后部署了官方默认的web_demo、api_demo两种模式;重新设计了前端,支持H5和安卓两个客户端调用。但却发现了不能并发访问的问题。问题现象在安卓与H5同时调......
  • python计算机毕设【附源码】基于html的校园网设计与实现(django+mysql+论文)
    本系统(程序+源码)带文档lw万字以上  文末可获取本课题的源码和程序系统程序文件列表系统的选题背景和意义选题背景:在信息技术快速发展的今天,互联网已经成为人们获取信息、交流沟通的重要平台。对于学校而言,拥有一个功能齐全、操作简便的校园网系统显得尤为重要。基于HTML......
  • python计算机毕设【附源码】基于MySQL的房屋中介系统(django+mysql+论文)
    本系统(程序+源码)带文档lw万字以上  文末可获取本课题的源码和程序系统程序文件列表系统的选题背景和意义选题背景:在当今社会,房地产市场的繁荣发展使得房屋中介行业成为了连接房东与租户、买家之间的重要桥梁。随着互联网技术的不断进步和普及,传统的房屋中介服务方式已经......
  • 用Go语言写了一个加班就自动发信息给老婆的脚本
    用Go语言写了一个加班就自动发信息给老婆的脚本。。。原创 磊丰 Go语言圈 2024-04-0908:30 美国 听全文Go语言圈Go语言开发者的学习好助手,分享Go语言知识,技术技巧,学习与交流Go语言开发经验,互动才有助于技术的提升,每天5分钟,助你GO语言技术快乐成长156篇原......
  • 【go】golang中的通道
    通道:channel名词:在goroutine中通信的管道注意:任何时候,同一时刻只能有一个goroutine访问通道进行发送和获取数据通道的顺序:遵循先入先出的规则通道的定义//定义一个通道var变量名chan数据类型//比如:varintChchanint64varstrChchanstringvarmapChchanm......