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的这套并发模型,强大就强大在它把复杂的并发控制抽象成了几个简单易懂的原语,用起来顺手,效率也高,非常适合处理各种需要并发的场景。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
jar运行报错nomainmanifestattribute原因分析及解决
jar运行报错no main manifest attribute 部署到服务器,满怀期待地执行那条经典命令: ja va -jar test-0 0 1-SNAPSHOT jar 结果迎面而来的却是一盆冷水: no main manifest attribute, in test-0 0 1-SN
内核编程与应用编程对比
内核编程与应用编程的核心差异 探索底层技术、研读Linux内核源码,始终是众多开发者热衷的方向。然而客观而言,尽管兴趣浓厚,专职从事内核开发的实际岗位却相对有限。以我个人经历为例,早期工作虽涉及负载均衡领域,但数据处理层面仍集中于应用层——当然,这已与传统应用编程中常见的业务逻辑开发存在显著区别。
python使用pdfplumber库一键提取pdf中的所有超链接
前言 在PDF文档中,可点击的超链接在技术规范中被称为“链接注释”。 根据PDF标准,链接注释是一种特殊的注释类型。其核心机制定义了用户的可点击区域、指定了跳转目标(可以是外部网页URL,也可以是文档内部的特定页面),并允许设置视觉呈现样式。正是基于这一设计,PDF阅读器才能识别并响应用户的点击交互
Python判断字符串是否为数字,浮点数或者字母
前言 在Python编程实践中,字符串类型转换是一项高频操作。开发者经常需要将字符串转换为整数或浮点数,但转换过程并非总能成功。例如,若直接将包含乘号的字符串“12*76”传递给int()函数,程序会立即抛出ValueError异常,因为“*”无法被解析为数字。因此,在尝试转换前,预先判断一个字符串
Python版本与supervisor版本的兼容性详解
1 通用兼容性 首先,我们来深入探讨Python版本与Supervisor进程管理工具的通用匹配原则。总体而言,这套组合的向下兼容性表现优异,但不同发布时期的版本,其“最佳搭档”也各有侧重。 Python 2 7: 作为经典的旧版运行时,如果你仍在维护使用此版本的项目,可以放心,Superviso
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

