Go语言在CentOS上如何实现并发编程
在CentOS上使用Go语言实现并发编程
想在CentOS系统里玩转Go语言的并发编程?这事儿其实没想象中那么复杂。Go语言自带的并发模型——也就是Goroutines和Channels——设计得非常精妙,用起来既高效又直观。下面咱们就一步步来,看看怎么在CentOS上搭建环境并写出你的第一个并发程序。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
1. 安装Go语言环境
第一步,当然是得先把Go语言环境给装上。如果你的CentOS系统里还没有,跟着下面这几行命令走就行:
# 下载Go语言安装包
wget https://golang.org/dl/go1.20.4.linux-amd64.tar.gz
# 解压安装包到/usr/local目录
sudo tar -C /usr/local -xzf go1.20.4.linux-amd64.tar.gz
# 配置环境变量
echo "export PATH=$PATH:/usr/local/go/bin" >> ~/.bashrc
source ~/.bashrc
# 验证安装
go version
跑完最后一句go version,如果能看到版本号蹦出来,那就恭喜你,环境搞定了一半。
2. 创建Go项目
环境好了,接下来得有个地方写代码。创建一个专属的项目目录,并且初始化Go模块,这样管理依赖会方便很多:
mkdir myconcurrencyproject
cd myconcurrencyproject
go mod init myconcurrencyproject
3. 编写并发程序
重头戏来了。在项目里创建一个main.go文件,然后把下面的代码贴进去。这个例子展示了如何使用Goroutines和WaitGroup来并发执行多个“工人”任务:
package main
import (
"fmt"
"sync"
"time"
)
func worker(id int, wg *sync.WaitGroup) {
defer wg.Done()
fmt.Printf("Worker %d starting\n", id)
time.Sleep(time.Second)
fmt.Printf("Worker %d done\n", id)
}
func main() {
var wg sync.WaitGroup
// 启动多个Goroutines
for i := 1; i <= 5; i++ {
wg.Add(1)
go worker(i, &wg)
}
// 等待所有Goroutines完成
wg.Wait()
fmt.Println("All workers done")
}
4. 运行程序
代码写好了,跑起来看看效果。在终端里输入:
go run main.go
你会看到五个“工人”几乎同时开始工作,又在一秒后陆续完成任务,最后主程序收到“全部完成”的信号。这就是并发最直观的体现。
解释
这里用到了两个核心概念:
- Goroutines:你可以把它理解成Go语言里的“轻量级线程”,用个
go关键字就能启动,开销极小,由Go运行时自己管理调度。 - WaitGroup:它的作用就像个任务计数器,专门用来等一队Goroutines干完活。
wg.Add(1)是发任务牌,wg.Done()是交还任务牌,wg.Wait()则像个监工,一直等到所有任务牌都收回来才放行。
5. 使用Channels进行通信
光能同时跑任务还不够,任务之间还得能“对话”。这就是Channel的用武之地了,它是Goroutines之间通信和同步的桥梁。再看一个生产者和消费者的例子:
package main
import (
"fmt"
"sync"
"time"
)
func producer(ch chan<- int) {
for i := 1; i <= 5; i++ {
ch <- i
time.Sleep(time.Second)
}
close(ch)
}
func consumer(ch <-chan int, wg *sync.WaitGroup) {
defer wg.Done()
for num := range ch {
fmt.Printf("Received: %d\n", num)
}
}
func main() {
ch := make(chan int)
var wg sync.WaitGroup
wg.Add(2)
go producer(ch)
go consumer(ch, &wg)
wg.Wait()
fmt.Println("Done")
}
解释
这段代码又引入了新玩法:
- Channels:注意看函数参数里的
chan<- int和<-chan int,这可不是随便写的。前者定义了一个“只发送”通道,后者定义了一个“只接收”通道。这种单向Channel的用法,能在编译阶段就帮我们避免很多数据竞争的错误,让代码更安全。 - WaitGroup:在这里继续扮演协调者的角色,确保生产和消费两个环节都完成后,程序才优雅退出。
走完这几个步骤,你应该就能在CentOS上轻松驾驭Go的并发编程了。Go的这套并发模型,强大就强大在它把复杂的并发控制抽象成了几个简单易懂的原语,用起来顺手,效率也高,非常适合处理各种需要并发的场景。
相关攻略
在CentOS系统中调试Node js错误,可以采用以下方法 遇到Node js应用报错,别急着重启服务。先稳住,系统性地排查,往往能更快定位问题根源。下面这几种方法,从基础到进阶,总有一款适合你。 1 查看日志文件 这是最直接的第一步。Node js应用运行时,错误信息通常会实时输出到控制台。所
在CentOS上配置Python自动化任务 你是否需要在CentOS服务器上部署一个稳定、高效的Python自动化任务?无论是数据同步、日志清理还是系统监控,通过Python脚本结合Linux定时任务都能轻松实现。本文将为你提供一份从环境准备到任务部署的完整CentOS Python自动化配置指南,
在CentOS系统中高效管理Python依赖,构建一个独立、清晰的环境至关重要。这不仅能够有效防止不同项目间的包版本冲突,还能显著简化部署流程与团队协作。本文将详细介绍一套基于pip与virtualenv的标准化操作流程,这是在Linux服务器上进行Python项目依赖管理的成熟方案。 1 安装P
在CentOS上配置Python错误处理:构建稳定应用的完整指南 在CentOS服务器环境中部署Python应用程序时,建立一套完善的错误处理机制至关重要。这不仅是系统稳定运行的“安全网”,更是快速定位和解决问题的“导航仪”。合理的错误配置能够将故障排查时间缩短数倍,避免小问题演变为服务中断。 本文
在CentOS系统中为Python应用配置内存限制 在CentOS服务器上运行Python应用时,有效管理内存使用是保障系统稳定性和应用性能的关键。通常需要从操作系统和应用程序两个层面协同配置,才能从根本上预防内存溢出(OOM)问题,实现资源的精细化管控。 操作系统级别的内存限制 首先,从系统层面入
热门专题
热门推荐
红米Note 11 Pro系统升级,为何坚持要求连接Wi-Fi? 当红米Note 11 Pro收到MIUI或澎湃OS的系统更新推送时,官方总会明确提示:整个过程请在Wi-Fi网络环境下完成。这项要求并非随意设定,而是基于清晰的技术与体验考量。一次完整的系统升级包,其大小通常在2GB至4GB之间。如果
小米13 Ultra的NFC功能深度解析:它如何重新定义“全场景智能交互”? 在旗舰手机领域,NFC功能看似已成为标配,但体验却千差万别。小米13 Ultra所搭载的全功能NFC方案,在“全能”与“好用”两个维度上树立了新的标杆。它不仅无缝集成了公交卡模拟、门禁卡复制、数字车钥匙等核心生活服务,更全
嵌入式消毒柜电源插座安装指南:隐蔽式布局提升安全与美观 在规划嵌入式消毒柜的安装方案时,电源插座的布局方式直接影响到最终的整体效果与安全性。正确的做法是避免插座外露,采用隐蔽式安装。根据国家《住宅厨房设计规范》及主流厨电品牌的安装标准,推荐将插座预留在消毒柜后方或侧方的墙体内部,安装高度宜控制在距地
是的,魔音(Beats)耳机充电状态一目了然,指示灯明确显示 当你为Beats头戴式耳机充电时,如何判断它是否已经充满?答案就藏在机身自带的五段式LED电量指示灯里。在充电过程中,这排指示灯会持续闪烁,实时反馈充电进度。一旦所有五个指示灯全部转为稳定常亮、不再闪烁,即代表电池已完全充满。整个充电周期
博朗剃须刀型号全解析:从编码规则到选购技巧的终极指南 面对博朗剃须刀复杂的字母数字组合感到困惑?实际上,其型号命名体系逻辑严谨,是用户选购的核心依据。简单来说,型号首位的数字(1、3、5、7、9)直接代表产品系列,数字越大,通常意味着技术越先进、功能越全面、定位越高端。例如,顶级的9系旗舰机型普遍搭





