商城首页欢迎来到中国正版软件门户

您的位置:首页 >Ubuntu中Golang并发编程怎么写

Ubuntu中Golang并发编程怎么写

  发布于2026-05-02 阅读(0)

扫一扫,手机访问

在Ubuntu中编写Golang并发程序

想在Ubuntu系统里玩转Golang的并发编程?其实核心就是掌握好goroutines和channels这两个原语。下面通过一个具体的例子,带你走一遍完整的流程,看看如何让多个任务在Ubuntu环境下协同工作。

Ubuntu中Golang并发编程怎么写

第一步:环境准备

首先,确保你的Ubuntu系统已经安装了Golang。如果还没安装,直接去官网(https://golang.org/dl/)下载对应版本的安装包,按照指引完成安装即可。

第二步:创建项目文件

接下来,创建一个新的Go文件,比如就叫它 main.go,然后用你喜欢的文本编辑器打开它。

第三步:编写并发代码

main.go 文件中,输入以下代码:

package main

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

func main() {
    var wg sync.WaitGroup

    // 创建一个channel,用于在goroutines之间传递数据
    dataChan := make(chan int)

    // 启动一个goroutine,用于向channel发送数据
    wg.Add(1)
    go func() {
        defer wg.Done()
        for i := 0; i < 5; i++ {
            dataChan <- i
            time.Sleep(1 * time.Second)
        }
        close(dataChan)
    }()

    // 启动另一个goroutine,用于从channel接收数据并处理
    wg.Add(1)
    go func() {
        defer wg.Done()
        for data := range dataChan {
            fmt.Println("Received data:", data)
        }
    }()

    // 等待所有goroutines完成
    wg.Wait()
    fmt.Println("All goroutines finished.")
}

这段代码做了几件关键的事:它使用 sync.WaitGroup 来确保主程序等待所有“子任务”完成。同时,创建了一个名为 dataChan 的通道(channel),作为goroutines之间的数据传输管道。代码启动了两个goroutine:一个负责每隔一秒向通道发送一个数字,发送完毕后会关闭通道;另一个则持续从通道接收数据并打印出来。这种“生产者-消费者”模式是并发编程中的经典场景。

第四步:编译与运行

保存好文件后,打开终端,切换到文件所在目录,运行下面这条命令:

go run main.go

第五步:观察结果

现在,观察终端的输出。你会看到两个goroutine在同时运行:一个在后台默默发送数据,另一个则实时接收并打印出这些数据。整个过程是并发进行的,而不是顺序执行。

通过这个简单的示例,你应该对在Ubuntu中使用Golang进行并发编程有了一个直观的感受。当然,这只是个起点。你可以基于这个模式,修改和扩展代码,来实现更复杂的并发逻辑,比如处理更多任务、使用带缓冲的通道,或者引入更精细的同步机制。关键在于理解goroutine的轻量和channel的通信能力,剩下的就是你的想象力了。

本文转载于:https://www.yisu.com/ask/77080133.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注