GoLang并发与并行

Go 里的并发(Concurrency)并行(Parallelism) ,是面试高频、也是理解 goroutine 的核心。给你一套能讲清 + 能拿分的版本👇


🎯 一句话核心区别

并发是"同时处理多个任务的能力",并行是"同时执行多个任务的能力"。


🧠 一、并发(Concurrency)

👉 重点:任务可以交替执行

即使只有 1 个 CPU 核心,也能并发。

示例

复制代码
go task1()
go task2()

在单核情况下:

  • 执行 task1 一会

  • 切到 task2

  • 再切回来

➡️ 本质:调度切换


特点

  • 不一定同时执行

  • 是一种"程序结构设计"

  • Go 用 goroutine + channel 实现


🚀 二、并行(Parallelism)

👉 重点:多个任务真正同时执行

必须依赖:

  • 多核 CPU

  • Go 调度器(GMP)


示例

2 核 CPU:

  • task1 在 核1 跑

  • task2 在 核2 跑

➡️ 真正同时执行


特点

  • 一定同时执行

  • 用于提升计算速度

  • 属于"硬件 + 调度能力"


⚙️ 三、Go 是怎么实现的?

Go 的核心设计:

用 goroutine 实现并发,用 GMP 调度实现并行


🔑 关键点

1️⃣ goroutine = 并发单位

不是线程,也不等于并行


2️⃣ 是否并行取决于:

复制代码
runtime.GOMAXPROCS(n)

👉 默认:

= CPU 核心数


3️⃣ GMP 模型作用

  • G(goroutine)

  • P(调度器)

  • M(线程)

👉 调度流程:

复制代码
G → P → M → CPU 执行

🍳 四、一个非常好用的类比(面试加分)

并发(一个人做多件事)

一个厨师:

  • 一会炒菜

  • 一会切菜

  • 一会煮面

➡️ 来回切换


并行(多个人同时做)

多个厨师:

  • 一个炒菜

  • 一个煮面

  • 一个切菜

➡️ 同时进行


🔥 五、Go 代码对比(面试常用)

并发(未必并行)

复制代码
for i := 0; i < 2; i++ {
    go func(i int) {
        fmt.Println(i)
    }(i)
}
time.Sleep(time.Second)

👉 有多个 goroutine,但不保证同时执行


并行(利用多核)

复制代码
runtime.GOMAXPROCS(4)

👉 允许 4 个线程同时运行


⚠️ 六、常见误区(一定要会)

❌ goroutine = 并行

👉 错,只是并发


❌ 并发一定更快

👉 不一定:

  • 有上下文切换开销

  • 有锁竞争


❌ 开越多 goroutine 越好

👉 错:

  • CPU 密集 → 会更慢

  • 调度压力大


🧩 七、终极总结(面试王炸)

👉 直接这样说:

在 Go 中,并发是通过 goroutine 实现的任务组织方式,而并行是通过 GMP 调度器在多核 CPU 上同时执行多个 goroutine。goroutine 本身不保证并行,是否并行取决于运行环境和调度器配置。

相关推荐
木雷坞9 小时前
Go 项目实战:用 MLiev IAM 落地企业认证中心
后端·golang·认证
知彼解己20 小时前
LLM-based Planning:从后端视角理解 Agent 规划层
后端·golang·ai编程
basketball6161 天前
Go语言从入门到进阶:8. 接口
开发语言·后端·golang
codeejun1 天前
每日一Go-71、理论知识:CAP 、一致性原理 、Raft 机制(简化实现一个 Raft)
java·开发语言·golang
曾几何时`1 天前
Go(一)Gin框架 和 GORM机制
开发语言·golang·gin
l齐天1 天前
Ubuntu 22.04 环境下 PBC 与 Golang 的安装、配置与测试
linux·ubuntu·golang
codeejun1 天前
每日一 Go-72、分布式事务 & 一致性:本地消息表、事务消息、SAGA、TCC怎么选?
开发语言·分布式·golang
喵了几个咪2 天前
AI重构软件开发范式:框架与脚手架为何仍是生产级开发的刚需?
vue.js·人工智能·react.js·重构·golang·ai编程
go不是csgo2 天前
Go-GMP-调度器深度解析(改进版本)
java·linux·golang
知彼解己2 天前
SQLite 核心实战:后端工程师视角
后端·golang·ai编程