当前位置: 首页 > news >正文

【Go 语言】揭秘 Go 语言的并发魔法:Goroutine 入门指南

揭秘 Go 语言的并发魔法:Goroutine 入门指南

你是否曾经编写过一个程序,当它在等待网络响应或读取大文件时,整个应用就卡在那里一动不动?或者你是否想让程序同时处理多个任务,却被传统线程编程的复杂性和高昂开销吓退?

如果答案是肯定的,那么 Go 语言的 Goroutine 将会是你梦寐以求的解决方案。Goroutine 是 Go 语言并发设计的核心,它让编写高性能的并发程序变得前所未有的简单和优雅。

今天,就让我们一起揭开 Goroutine 的神秘面纱。

什么是 Goroutine?🤔

想象你是一位餐厅的主厨(main 函数)。你的任务是准备一顿包含“切菜”、“炖汤”和“烤面包”的大餐。

传统的做法(同步执行):
你亲力亲为,先花 10 分钟切菜,再花 30 分钟炖汤,最后花 15 分钟烤面包。整个过程耗时 55 分钟,并且在你炖汤的时候,烤箱和砧板都是空闲的,效率极低。

Goroutine 的做法(并发执行):
你是一位聪明的主厨!你没有自己做所有事,而是:

  1. 雇佣一个帮厨(启动一个 Goroutine),让他去切菜
  2. 同时,你启动了智能炖锅(启动另一个 Goroutine)去炖汤
  3. 然后,你把面包放进自动烤箱(再启动一个 Goroutine)去烘烤

你把任务分配出去后,自己就可以去准备调料,或者监督进度。这几项任务在同时进行,大大缩短了总时间。

Goroutine 就是 Go 程序中的“帮厨”。它是一个极其轻量级的执行单元,可以与其它 Goroutine 同时运行。

它的特点是:

  • 轻量:一个 Goroutine 只占用几 KB 的内存,你可以在一个程序中轻松创建成千上万个。
  • 高效:由 Go 运行时(Go Runtime)而非操作系统直接管理,切换成本极低。
  • 简单:启动一个 Goroutine 只需要一个关键字。
如何施展魔法:go 关键字 ✨

在 Go 语言中,启动一个 Goroutine 简单到令人发指。你只需要在函数调用前加上 go 关键字即可。

package mainimport ("fmt""time"
)func sayHello() {fmt.Println("Hello from the new goroutine!")
}func main() {// 就像主厨派出一个帮厨去打招呼go sayHello()fmt.Println("Hello from the main goroutine!")
}

当你运行这段代码时,你可能会遇到一个奇怪的现象:你可能只看到了 “Hello from the main goroutine!”,而另一句话没有出现。

这是为什么?因为 main 函数(主厨)派出了任务后,没有等待帮厨完成就直接“下班”了(程序退出)。主 Goroutine 退出时,所有其他的 Goroutine 都会被强制终止。

那么,我们如何让主厨等待帮厨完成工作呢?答案是:通信

Goroutine 间的沟通桥梁:Channel 📮

如果多个帮厨之间不沟通,厨房很快就会乱作一团。在 Go 中,Goroutine 之间推荐的通信方式是 Channel(通道)

你可以把 Channel 想象成厨房里的一个神奇传送带:

  • 一个 Goroutine 可以把完成的菜(数据)放到传送带上。
  • 另一个 Goroutine 可以从传送带上取走菜(数据)。
  • 如果传送带上没东西,想取东西的 Goroutine 就会等待
  • 如果传送带满了,想放东西的 Goroutine 也会等待

这种“等待”机制完美地解决了同步问题。让我们用 Channel 改进一下刚才的例子:

package mainimport ("fmt""time"
)// worker 函数现在接收一个 channel
func doSomeWork(done chan bool) {fmt.Println("Worker: 开始工作...")time.Sleep(2 * time.Second) // 模拟耗时工作fmt.Println("Worker: 工作完成!")// 工作完成后,通过 channel 发送一个信号done <- true
}func main() {// 1. 创建一个用于通信的 channeldoneChannel := make(chan bool)fmt.Println("Main: 指派任务给 worker...")// 2. 启动 worker goroutine,并把 channel 传给它go doSomeWork(doneChannel)// 3. Main goroutine 在这里等待从 channel 接收信号// 这一步会阻塞,直到 worker 发送信号过来<-doneChannelfmt.Println("Main: 收到 worker 完成信号,程序退出。")
}

程序输出:

Main: 指派任务给 worker...
Worker: 开始工作...
Worker: 工作完成!
Main: 收到 worker 完成信号,程序退出。

这次,main 函数通过 <-doneChannel 一直等待,直到 doSomeWork Goroutine 完成工作并通过 done <- true 发送了完成信号。一切都按预期的顺序发生了!

结论

Goroutine 是 Go 语言的王牌特性,它将复杂的并发编程抽象成了“雇佣帮厨去干活”这样简单的模型。

记住这几个核心要点:

  1. Goroutine 是并发执行的轻量级“工人”。
  2. 使用 go myFunction() 即可启动一个 Goroutine。
  3. Channel 是 Goroutine 之间传递数据和进行同步的安全桥梁。

Go 的设计哲学是:“不要通过共享内存来通信,而要通过通信来共享内存。” Channel 和 Goroutine 正是这一哲学的完美体现。

现在,你已经掌握了 Go 并发编程的基础。去尝试一下,在你自己的代码中召唤几个 Goroutine,感受一下并发带来的性能提升和编程乐趣吧!🚀

http://www.dtcms.com/a/438906.html

相关文章:

  • 工商企业信息查询网站深圳宝安龙岗紧急寻人
  • 怎么上传视频到公司网站西安seo排名扣费
  • cms(网站内容管理系统)有哪些商业信息网站大全
  • Redis面试题及详细答案100道(86-100) --- 综合篇
  • 贪心算法:原理与实战全解析
  • python评估算法性能
  • 408之cpp(二叉树的广度优先遍历)
  • 保定市网站销售和设计中国各大网站开发语言
  • 本地常州微信网站建设做网站税率
  • 网页设计 做网站的代码公司网站开发项目管理制度
  • EFlat-LoRA 的严格数学推导
  • 【面板数据】全国分省教育支出水平数据集(2007-2023年)
  • 做网站工商局要不要备案呢wordpress主题多页面
  • 济南网站建设服务公司wordpress 远程插件安装 ftp
  • 济南网站建设公司按需定制保险网站建设的目标
  • 深入剖析:boost::intrusive_ptr 与 std::shared_ptr 的性能边界和实现哲学
  • 聊城制作手机网站公司网站建设需要的条件
  • SQL 子查询与多表 JOIN 用法大全(速查版)
  • Leetcode 239. 滑动窗口最大值 优先队列 / 双向单调队列
  • Nacos 工作原理及流量走向
  • 夏津网站建设茂名企业建站程序
  • OSPF 单区域实验 概念及题目
  • 建立一个门户网站WordPress域名后问号英文
  • 自上而下VS自下而上:设计哲学全解
  • 【开题答辩全过程】以 SpringCloud家乡美旅行交流博客平台为例,包含答辩的问题和答案
  • 2015优先中文公司官网wordpress模板
  • 国外优秀企业网站网络空间的竞争归根结底是
  • 哪些外贸网站可以做soho求网站2021给个网址
  • 2022年网站能用的兰州企业网站制作
  • 网页设计与网站建设实战大全推荐好的网站或网页